SQLAlchemy 中的 Engine 是什么?
先看这张图,这是从官方网站扒下来的。
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?charset=utf8mb4')
构建好
Engine
对象的同时,
连接池
和
Dialect
也创建好了,但是这时候并不会立马与数据库建立真正的连接,只有你调用
Engine.connect()
或者
Engine.execute(sql)
执行SQL请求的时候,才会建立真正的连接。因此 Engine 和 Pool 的行为称之为延迟初始化,用现在流行的话来说就是延迟满足感,等真正要派上用场的时候才去建立连接。
需要注意的是,创建引擎时,如果数据库的密码含有特殊字符,需要先编码处理
>>> import urllib.parse