【发布时间】:2018-09-08 23:07:04
【问题描述】:
我有一个原始的 sql 查询是:
select distinct(user_id) from details_table where event_id in (29,10) and user_id in (7,11,24,45) and epoch_timestamp >= 1433116800 and epoch_timestamp <= 1506816000;
psql 中的返回:
user_id
---------
7
24
(2 rows)
现在,当我通过 sqlalchemy 运行这个原始 sql 查询时,我得到一个 sqlalchemy.engine.result.ResultProxy 对象作为响应,而不是上面的结果。我现在使用的代码如下:
from flask import current_app
sql_query = text(select distinct(user_id) from details_table where event_id in (29,10) and user_id in (7,24) and epoch_timestamp >= 1433116800 and epoch_timestamp <= 1506816000;)
filtering_users = db.get_engine(current_app, bind='<my_binding>')\
.execute(sql_query)
print(type(filtering_users))
# <class 'sqlalchemy.engine.result.ResultProxy'>
print(filtering_users)
# <sqlalchemy.engine.result.ResultProxy object at 0x7fde74469550>
我使用了来自 here 的引用,但与那里的解决方案不同的是,我得到了一个 ResultProxy 对象。
我在这里做错了什么?我的最终目标是获取从执行原始 sql 查询返回的用户列表,并将其存储到列表中。
【问题讨论】:
标签: python postgresql sqlalchemy flask-sqlalchemy