返回顶部
首页 > 资讯 > 后端开发 > Python >Python玩转SQL的神器有哪些
  • 916
分享到

Python玩转SQL的神器有哪些

2023-07-06 02:07:34 916人浏览 泡泡鱼

Python 官方文档:入门教程 => 点击学习

摘要

这篇文章主要讲解了“python玩转sql的神器有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Python玩转SQL的神器有哪些”吧!初始化工作一般使用ORM框架,都会有一些初始化工作

这篇文章主要讲解了“python玩转sql的神器有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Python玩转SQL的神器有哪些”吧!

初始化工作

一般使用ORM框架,都会有一些初始化工作,比如数据库连接,定义基础映射等。

MySQL为例,创建数据库连接只需要传入DSN字符串即可。其中echo表示是否输出对应的sql语句,对调试比较有帮助。

from sqlalchemy import create_engineengine = create_engine('Mysql+pymysql://$user:$passWord@$host:$port/$db?charset=utf8mb4', echo=True)

个人设计

对于我个人而言,引进ORM框架时,我的项目会参考mvc模式做以下设计。其中model存储的是一些数据库模型,即数据库表映射的Python类;model_op存储的是每个模型对应的操作,即增删查改;调用方(如main.py)执行数据库操作时,只需要调用model_op层,并不用关心model层,从而实现解耦。

├── main.py├── model│ ├── __init__.py│ ├── base_model.py│ ├── ddl.sql│ └── py_orm_model.py└── model_op ├── __init__.py └── py_orm_model_op.py

映射声明(Model介绍)

举个栗子,如果我们有这样一张测试

create table py_orm ( `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '唯一id', `name` varchar(255) NOT NULL DEFAULT '' COMMENT '名称', `attr` JSON NOT NULL COMMENT '属性', `ct` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', `ut` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON update CURRENT_TIMESTAMP COMMENT '更新时间', PRIMARY KEY(`id`))ENGINE=InnoDB COMMENT '测试表';

在ORM框架中,映射的结果就是下文这个Python类

# py_orm_model.pyfrom .base_model import Basefrom sqlalchemy import Column, Integer, String, TIMESTAMP, text, jsONclass PyOrmModel(Base): __tablename__ = 'py_orm' id = Column(Integer, autoincrement=True, primary_key=True, comment='唯一id') name = Column(String(255), nullable=False, default='', comment='名称') attr = Column(JSON, nullable=False, comment='属性') ct = Column(TIMESTAMP, nullable=False, server_default=text('CURRENT_TIMESTAMP'), comment='创建时间') ut = Column(TIMESTAMP, nullable=False, server_default=text('CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP'), comment='更新时间')

首先,我们可以看到PyOrmModel继承了Base类,该类是sqlalchemy提供的一个基类,会对我们声明的Python类做一些检查,我将其放在base_model中。

# base_model.py# 一般base_model做的都是一些初始化的工作from sqlalchemy import create_enginefrom sqlalchemy.ext.declarative import declarative_baseBase = declarative_base()engine = create_engine("mysql+pymysql://root:123456@127.0.0.1:33306/orm_test?charset=utf8mb4", echo=False)

其次,每个Python类都必须包含__tablename__属性,不然无法找到对应的表。

第三,关于数据表的创建有两种方式,第一种当然是手动在MySQL中创建,只要你的Python类定义没有问题,就可以正常操作;第二种是通过orm框架创建,比如下面:

# main.py# 注意这里的导入路径,Base创建表时会寻找继承它的子类,如果路径不对,则无法创建成功from sqlachlemy_lab import Base, engineif __name__ == '__main__': Base.metadata.create_all(engine)

创建效果:

...2020-04-04 10:12:53,974 INFO sqlalchemy.engine.base.EngineCREATE TABLE py_orm (id INTEGER NOT NULL AUTO_INCREMENT,name VARCHAR(255) NOT NULL DEFAULT '' COMMENT '名称',attr JSON NOT NULL COMMENT '属性',ct TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,ut TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, PRIMARY KEY (id))

第四,关于字段属性

  • primary_key和autoincrement比较好理解,就是MySQL的主键和递增属性。

  • 如果是int类型,不需要指定长度,而如果是varchar类型,则必须指定。

  • nullable对应的就是MySQL中的NULL 和 NOT NULL

  • 关于default和server_default: default代表的是ORM框架层面的默认值,即插入的时候如果该字段未赋值,则会使用我们定义的默认值;server_default代表的是数据库层面的默认值,即DDL语句中的default关键字。

Session介绍

在SQLAlchemy的文档中提到,数据库的增删查改是通过session来执行的。

>>> from sqlalchemy.orm import sessionmaker>>> Session = sessionmaker(bind=engine)>>> session = Session()>>> orm = PyOrmModel(id=1, name='test', attr={})>>> session.add(orm)>>> session.commit()>>> session.close()

如上,我们可以看到,对于每一次操作,我们都需要对session进行获取,提交和释放。这样未免过于冗余和麻烦,所以我们一般会进行一层封装。

采用上下文管理器的方式,处理session的异常回滚和关闭,这部分与所参考的文章是几乎一致的。

# base_model.pyfrom contextlib import contextmanagerfrom sqlalchemy.orm import sessionmaker, scoped_sessiondef _get_session(): """获取session""" return scoped_session(sessionmaker(bind=engine, expire_on_commit=False))()# 在这里对session进行统一管理,包括获取,提交,回滚和关闭@contextmanagerdef db_session(commit=True): session = _get_session() try: yield session if commit: session.commit() except Exception as e: session.rollback() raise e finally: if session: session.close()

在PyOrmModel中增加两个方法,用于model和dict之间的转换

class PyOrmModel(Base): ... @staticmethod def fields(): return ['id', 'name', 'attr'] @staticmethod def to_json(model): fields = PyOrmModel.fields() json_data = {} for field in fields: json_data[field] = model.__getattribute__(field) return json_data @staticmethod def from_json(data: dict): fields = PyOrmModel.fields() model = PyOrmModel() for field in fields: if field in data: model.__setattr__(field, data[field]) return model

数据库操作的封装,与参考的文章不同,我是直接调用了session,从而使调用方不需要关注model层,减少耦合。

# py_orm_model_op.pyfrom sqlachlemy_lab.model import db_sessionfrom sqlachlemy_lab.model import PyOrmModelclass PyOrmModelOp: def __init__(self): pass @staticmethod def save_data(data: dict): with db_session() as session: model = PyOrmModel.from_json(data) session.add(model) # 查询操作,不需要commit @staticmethod def query_data(pid: int): data_list = [] with db_session(commit=False) as session: data = session.query(PyOrmModel).filter(PyOrmModel.id == pid) for d in data: data_list.append(PyOrmModel.to_json(d)) return data_list

调用方

# main.pyfrom sqlachlemy_lab.model_op import PyOrmModelOpif __name__ == '__main__': PyOrmModelOp.save_data({'id': 1, 'name': 'test', 'attr': {}})

感谢各位的阅读,以上就是“Python玩转SQL的神器有哪些”的内容了,经过本文的学习后,相信大家对Python玩转SQL的神器有哪些这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

--结束END--

本文标题: Python玩转SQL的神器有哪些

本文链接: https://lsjlt.com/news/357394.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Python玩转SQL的神器有哪些
    这篇文章主要讲解了“Python玩转SQL的神器有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Python玩转SQL的神器有哪些”吧!初始化工作一般使用ORM框架,都会有一些初始化工作...
    99+
    2023-07-06
  • 五分钟菜鸟学会Python玩转SQL的神器!
    背景其实一开始用的是pymysql,但是发现维护比较麻烦,还存在代码注入的风险,所以就干脆直接用ORM框架。ORM即Object Relational Mapper,可以简单理解为数据库表和Python类之间的映射,通过操作Python类,...
    99+
    2023-05-14
    Python SQL
  • 好玩的Python技术有哪些
    这篇文章主要介绍“好玩的Python技术有哪些”,在日常操作中,相信很多人在好玩的Python技术有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”好玩的Python技术有哪些”的疑惑有所帮助!接下来,请跟...
    99+
    2023-06-02
  • python神经网络框架有哪些
    python中神经网络框架有PyTorch、NeuroLab、Lasagne、Pyrenn几种PyTorchPytorch是一个有独特构建神经网络方法的包,Pytorch具有强大的GPU加速和深度神经网络建立的能力,常使用PyTorch来代...
    99+
    2024-04-02
  • sql将行转列的方法有哪些
    在SQL中,可以使用以下方法将行转列:1. 使用CASE语句:- 使用多个CASE语句,每个语句对应一个要转置的列,并使用不同的条件...
    99+
    2023-10-12
    sql
  • 云服务器有哪些玩法
    云服务器是一种虚拟的资源共享服务器,通常由大型数据中心提供,可以提供以下几种玩法:弹性计算:云服务器通常支持按需动态扩展,可以快速应对业务增长和变化的需求。可以利用云服务器的弹性计算功能,根据需求随时扩展服务器规模,提高资源利用率和灵活性,...
    99+
    2023-10-25
    玩法 服务器 有哪些
  • python中有哪些神经网络模块
    python中的神经网络模块有以下几种LasagneLasagne是一个轻量级的库,常用于建立和训练神经网络,其设计遵循了简单、透明、模块化、实用主义、约束性和重点性六个原则,支持前馈网络,如卷积神经网络。PyTorchPytorch是一个...
    99+
    2024-04-02
  • C++转Python的技巧有哪些
    本篇内容主要讲解“C++转Python的技巧有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C++转Python的技巧有哪些”吧!C++是跳水,Python 是潜水C++给人的感觉就像是一头...
    99+
    2023-06-15
  • Python代码中能玩的童年游戏有哪些
    这期内容当中小编将会给大家带来有关Python代码,能玩30多款童年游戏有哪些,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。大游戏小游戏有千千万万,这些小游戏应该只有90后才玩过和懂吧儿童节即将到来,虽然...
    99+
    2023-06-15
  • python转义字符有哪些
    python中常见的转义字符:1.\:续行符;2.\\:反斜杠符号;3.\’:单引号;4.\”:双引号;5.\a:响铃;6.\b:退格;python中常见的转义字符有以下几种\:续行符;\\:反斜杠符号;\’:单引号;\”:双引号;\a:响...
    99+
    2024-04-02
  • MySQL 中行列转换的SQL技巧有哪些
    这篇文章给大家分享的是有关MySQL 中行列转换的SQL技巧有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。行列转换常见场景 由于很多业务表因为历史原因或者性能原因,都使用...
    99+
    2024-04-02
  • sql转换成字符串的方法有哪些
    在SQL中,可以使用以下方法将数据转换为字符串: 使用CONVERT函数:CONVERT函数可以将数据类型转换为字符串。例如, ...
    99+
    2024-04-09
    sql
  • Python shapefile转GeoJson的方法有哪些
    这篇文章主要介绍“Python shapefile转GeoJson的方法有哪些”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Python shapefile转GeoJson的方法...
    99+
    2023-07-05
  • Swagger增强神器:Knife4j有哪些作用
    本篇内容主要讲解“Swagger增强神器:Knife4j有哪些作用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Swagger增强神器:Knife4j有哪些作用...
    99+
    2024-04-02
  • 有哪些Python转义表示法
    本篇内容介绍了“有哪些Python转义表示法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1. 为什么要有转义ASCII 表中一共有 128...
    99+
    2023-06-15
  • python object转换方式有哪些
    在Python中,有以下几种方式可以将对象进行转换: 使用内置函数str()、int()、float()等,将对象转换为字符串、...
    99+
    2023-10-24
    python object
  • 云服务器有哪些玩法和功能
    云服务器是一种虚拟的基础设施服务,用于托管和管理大量的计算资源。以下是一些可以用来玩的玩法和功能: 使用云服务器可用于创建虚拟机(VM),以在线创建、分发、管理和运行应用程序。 云服务器也可以用于管理虚拟机,包括分配虚拟机,监控和维护,...
    99+
    2023-10-26
    玩法 功能 服务器
  • 云服务器有哪些玩法和用途
    云服务器(Cloud Server)是一种虚拟服务器,可以在互联网上提供高速、稳定的网络基础设施服务。云服务器提供了诸如快照、故障转移、流量控制等功能,让用户可以随时随地访问和使用自己的云端资源。 以下是云服务器的一些玩法和用途: 快照...
    99+
    2023-10-26
    玩法 用途 服务器
  • 云服务器有哪些玩法和特点
    云服务器是一种虚拟的基础设施服务,通常被用于在云端托管应用程序和数据。以下是云服务器的一些玩法和特点: 玩法一:应用虚拟化 使用云服务器可以将应用程序虚拟成多个物理主机,从而减少了服务器的数量,并提高了服务器的效率。应用虚拟化技术可以将应...
    99+
    2023-10-26
    玩法 服务器 有哪些
  • Vue 开发中的编码效率神器有哪些?
    ...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作