我正在启动一个新应用程序并考虑使用 ORM——特别是 SQLAlchemy。
假设我的数据库中有一个“foo”列,我想增加它。在直接的 sqlite 中,这很容易:
db = sqlite3.connect('mydata.sqlitedb')
cur = db.cursor()
cur.execute('update table stuff set foo = foo + 1')
我想出了等效的 SQLAlchemy SQL-builder:
engine = sqlalchemy.create_engine('sqlite:///mydata.sqlitedb')
md = sqlalchemy.MetaData(engine)
table = sqlalchemy.Table('stuff', md, autoload=True)
upd = table.update(values={table.c.foo:table.c.foo+1})
engine.execute(upd)
这有点慢,但没有太多。
这是我对 SQLAlchemy ORM 方法的最佳猜测:
# snip definition of Stuff class made using declarative_base
# snip creation of session object
for c in session.query(Stuff):
c.foo = c.foo + 1
session.flush()
session.commit()
这样做是正确的,但它需要的时间是其他两种方法的不到 50 倍。我认为那是因为它必须先将所有数据带入内存,然后才能使用它。
有没有办法使用 SQLAlchemy 的 ORM 生成高效的 SQL?或者使用任何其他python ORM?还是我应该回去手动编写 SQL?