python SQLAlchemy 中的Engine详解
(编辑:jimmy 日期: 2026/1/22 浏览:3 次 )
先看这张图,这是从官方网站扒下来的。
Engine 翻译过来就是引擎的意思,汽车通过引擎来驱动,而 SQLAlchemy 是通过 Engine 来驱动,Engine 维护了一个连接池(Pool)对象和方言(Dialect)。方言简单而言就是你连的到底是 MySQL 还是 Oracle 或者 PostgreSQL 还是其它数据库,关于方言(Dialect)的介绍在另外一篇文章有介绍,可参考数据库方言dialect。
连接池很重要,因为每次发送sql查询的时候都需要先建立连接,如果程序启动的时候事先就初始化一批连接放在连接池,每次用完后又放回连接池给其它请求使用,就能大大提高查询的效率。
Engine 初始化
Engine 的初始化非常简单,通过工厂函数 create_engine 就可以创建。
from sqlalchemy import create_engine
engine = create_engine('mysql://user:password@localhost:3306/test"htmlcode">
> import urllib.parse
> urllib.parse.quote_plus("kx%jj5/g")
'kx%25jj5%2Fg'
其它数据库方言初始化 engine 的方式可参考官方文档
create_engine 还有很多可选参数,这里介绍几个重要的参数。
engine = create_engine('mysql://user:password@localhost:3306/test"external nofollow" target="_blank" href="https://docs.sqlalchemy.org/en/14/core/engines.html#database-urls">https://docs.sqlalchemy.org/en/14/core/engines.html#database-urls
https://stackoverflow.com/questions/34322471/sqlalchemy-engine-connection-and-session-difference
https://docs.sqlalchemy.org/en/13/core/pooling.html#dealing-with-disconnects
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
下一篇:python3.x+pyqt5实现主窗口状态栏里(嵌入)显示进度条功能
高通和谷歌日前宣布,推出首次面向搭载骁龙的Windows PC的优化版Chrome浏览器。
在对骁龙X Elite参考设计的初步测试中,全新的Chrome浏览器在Speedometer 2.1基准测试中实现了显著的性能提升。
预计在2024年年中之前,搭载骁龙X Elite计算平台的PC将面世。该浏览器的提前问世,有助于骁龙PC问世就获得满血表现。
谷歌高级副总裁Hiroshi Lockheimer表示,此次与高通的合作将有助于确保Chrome用户在当前ARM兼容的PC上获得最佳的浏览体验。
在对骁龙X Elite参考设计的初步测试中,全新的Chrome浏览器在Speedometer 2.1基准测试中实现了显著的性能提升。
预计在2024年年中之前,搭载骁龙X Elite计算平台的PC将面世。该浏览器的提前问世,有助于骁龙PC问世就获得满血表现。
谷歌高级副总裁Hiroshi Lockheimer表示,此次与高通的合作将有助于确保Chrome用户在当前ARM兼容的PC上获得最佳的浏览体验。
