以下是我尝试过的代码段
query = tbl_scores.select().limit( bindparam('lim') )
但是,我收到了以下错误。
TypeError: int() argument must be a string or a number, not 'BindParameter'
有人可以提供一个使用bindparam for LIMIT / OFFSET的例子吗?
Python 2.7.5,SQLAlchemy 0.8.4
假设webapi返回顶级玩家及其排名。使用像这样的绑定参数构造一个查询,然后将其存储在线程本地位置,以便请求可以共享相同的预编译查询。
# TypeError occurs here
a_thread_local_place.query = join(tbl_scores,
tbl_master_player,
tbl_scores.c.uid == tbl_master_player
).\
select().limit(bindparam('lim'))
每次webapi处理请求时,我都希望使用预编译查询执行这样的查询。
result = engine.connect().execute(
a_thread_local_place.query,
lim = 10,
)
答案 0 :(得分:2)
目前你不能,但是有一个未解决的问题,补丁正在进行中:
https://bitbucket.org/zzzeek/sqlalchemy/issue/3034/use-my-own-bindparam-for-querylimit