首页 > 数据库 >SQLAlchemy连接MySQL及记录的查询、更新、删除、多表关联查询

SQLAlchemy连接MySQL及记录的查询、更新、删除、多表关联查询

时间:2022-12-31 11:00:26浏览次数:69  
标签:SQLAlchemy 多表 查询 session User import query sqlalchemy pool


SQLAlchemy是Python的ORM库,支持多种数据库。

建立连接

连接MySQL要用到​​Engine​​,Engine集成了连接池pool和方言Dialect(支持不通数据库的SQL语法),最后都统一成标准DBAPI。

from sqlalchemy import create_engine
engine = create_engine('mysql+pymysql://root:root@localhost/test',
echo=True, pool_recycle=7200, pool_size=5, max_overflow=10, pool_timeout=30)

create_engine第一个参数是database url,用到了pymysql驱动。
参数echo用于打印执行中的关键日志,包括SQL执行语句。
pool_recycle表示connection空闲7200秒就会重新获取。
pool_size指定连接池大小。
max_overflow指定超过连接池大小的最大数。
pool_timeout获取连接的超时阈值。
poolclass设置为NullPool,禁用连接池,session.Close()之后会立即断开数据库连接。

报错:

2013, 'Lost connection to MySQL server during query 
([Errno 104] Connection reset by peer)

设置​​pool_pre_ping=True​​​和​​pool_recycle​​​可以每次执行都查看连接是否可用。
​​​pool_recycle​​​的值 应该比mysql中设置的 ​​interactive_timeout​​​ 和 ​​wait_timeout​​​ 值小才有效。
​​​pool_timeout​​​的值(默认10s) 应该比 mysql的 ​​connect_timeout​​值 小或者等于。

建立映射

sqlalchemy把表table映射成model class,把字段field映射成​​column​​,把记录record映射成实例instance。

手动创建映射

SQLAlchemy连接MySQL及记录的查询、更新、删除、多表关联查询_python

from sqlalchemy.sql.schema import Column
from sqlalchemy.types import BigInteger, String, Integer

Base = declarative_base()

class User(Base):
__tablename__ = 'users'

id = Column(BigInteger, primary_key=True)
name = Column(String(255))
age = Column(Integer)
gender = Column(String(255))

另外可以使用sqlacodegen(pip install sqlacodegen)自动生成model:

sqlacodegen mysql+pymysql://user:password@localhost/test --outfile=models.py --tables users
# coding: utf-8
from sqlalchemy import Column, String
from sqlalchemy.dialects.mysql import BIGINT, INTEGER
from sqlalchemy.ext.declarative import declarative_base

Base = declarative_base()
metadata = Base.metadata


class User(Base):
__tablename__ = 'users'

id = Column(BIGINT(20), primary_key=True)
name = Column(String(255, 'utf8_unicode_ci'))
age = Column(INTEGER(11))
gender = Column(String(255, 'utf8_unicode_ci'))

参考类型:

类型

介绍

Integer/BigInteger/SmallInteger

整型

Boolean

布尔类型. Python 中表现为 True/False , 数据库根据支持情况, 表现为 BOOLEAN 或 SMALLINT . 实例化时可以指定是否创建约束(默认创建).

Date/DateTime/Time (timezone=False)

日期类型, Time 和 DateTime 实例化时可以指定是否带时区信息

Interval

时间偏差类型. 在 Python 中表现为 datetime.timedelta() , 数据库不支持此类型则存为日期

Enum (*enums, **kw)

枚举类型, 根据数据库支持情况, SQLAlchemy 会使用原生支持或者使用 VARCHAR 类型附加约束的方式实现. 原生支持中涉及新类型创建, 细节在实例化时控制

Float

浮点小数

Numeric (precision=None, scale=None, decimal_return_scale=None, …)

定点小数, Python 中表现为 Decimal

LargeBinary (length=None)

字节数据. 根据数据库实现, 在实例化时可能需要指定大小

PickleType

Python 对象的序列化类型

String (length=None, collation=None, …)

字符串类型, Python 中表现为 Unicode , 数据库表现为 VARCHAR , 通常都需要指定长度

Unicode

类似与字符串类型, 在某些数据库实现下, 会明确表示支持非 ASCII 字符. 同时输入输出也强制是 Unicode 类型

Text

长文本类型, Python 表现为 Unicode , 数据库表现为 TEXT

UnicodeText

参考 Unicode

自动创建映射

from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.sql.schema import Table

Base = declarative_base()
metadata = Base.metadata
metadata.bind = engine


class User(Base):
__table__ = Table('users', metadata, autoload=True)

设置autoload就可以自动生成映射,另外Base.metadata需要提前绑定engine。

查询

from sqlalchemy.orm import sessionmaker

Session = sessionmaker(bind=engine)
session = Session()
query = session.query(User).filter(User.age >= 19).filter(User.name.like("王%"))
for user in query.all():
print(user.age)

查询用到了Session对象,类似一个容器,容器里是​​identity map​​​ 的结构对象。
用filter过滤数据。

新增

user1 = User()
user1.name = "赵六"
user1.age = 21
user1.gender = "女"
session.add(user1)
session.commit()

先建立一个User实例,然后调用session的add方法,最后commit。

更新

user2 = session.query(User).filter_by(name='赵六').first()
user2.gender = "男"
session.commit()

先查找到User实例,然后修改实例属性,最后调用session的commit修改数据库。

删除

user3 = session.query(User).filter_by(name='赵六').first()
session.delete(user3)
session.commit()

多表查询

Session = sessionmaker(bind=engine)
session = Session()
query = session.query(User, Address).join(Address, User.id == Address.user_id)
for user in query.all():
print(user[0].name)
print(user[1].add)

这里用了​​join方法​​。

参考

​http://sunnyingit.github.io/book/section_python/SQLalchemy-session.html​


标签:SQLAlchemy,多表,查询,session,User,import,query,sqlalchemy,pool
From: https://blog.51cto.com/lilongsy/5982047

相关文章

  • 一次多线程并发查询导致结果混乱的问题的排查和记录·JAVA·2022
    业务背景该业务是报表查询类业务:要求从销售出库数据(存储于ElasticSearch索引中)中,按照管理者分组聚合查询各个管理者一定时间段内的动销汇总数据,如出库金额、毛利率等。但......
  • Oracle_3_复制表、插入选择、递归查询
    一、复制表1、selectinto,使用查询结果新建表结构:createtable表名(字段名1,字段名2,......)asselect语句2、insertintoselect,使用查询结果插入到表中结构:inse......
  • mysql记录查询的sql
    showprocesslist;二、mysql查看已经执行的历史sql语句(方法:开启日志模式)开启日志SETGLOBALlog_output='TABLE';SETGLOBALgeneral_log='ON';查看是否开启showvaria......
  • mysql 关联查询速度慢 (解决)
     转载:https://blog.csdn.net/qq_48091113/article/details/122695260 1.记录原因:mysql关联查询速度很慢,是由于字段字符集规则不一致所导致1.1在一次线上的服务中,......
  • oracle 时间格式查询存储记录
    mybatis查询出oracle时间格式数据,选择何种数据类型能够接收问题:1、数据库中时间的存储,有哪几种类型2、这几种类型,对应使用mybatis查询出来,使用什么数据类型去接收数据......
  • MeterSphere 查询SQL引入接口做参数,前置SQL应用
    1、配置数据源在项目配置环境中编写数据库配置  2、编写SQL语句添加前置SQL 请求参数中使用  ${列名_1}指返回数据中第一个数值 参考:https://blog.cs......
  • 利用Python制作本地Excel的查询与生成的程序
    目录​​前言​​​​需求​​​​实验步骤​​​​Excel预览图片​​​​查询​​​​追加查询结果到Excel​​​​完整代码​​前言大家好我是毕加锁(锁!)今天教大家利......
  • Hive查询
    Hive查询1、基本查询查询语句SELECT[ALL|DISTINCT]select_expr,select_expr,...--查询表中的哪些字段FROMtable_reference --从哪个表查出来[W......
  • JavaWeb_多级查询 案例_表数据及练习详解
    此案例来自于B站黑马程序员JavaWeb教程,由于视频未给表数据,故特此手打于此,大家有需要可自取练习(也付有相应多级查询练习题和解答,可供参考)黑马程序员JavaWeb教程地址:https......
  • elastic-job2.1.5版本全量查询JOB_STATUS_TRACE_LOG的问题
    问题描述:在使用elastic-job的2.1.5版本开发时,因为有秒级任务发现有频繁的全量请求sql在执行:SELECToriginal_task_idFROMJOB_STATUS_TRACE_LOGWHEREtask_id='com.hori......