【发布时间】:2014-04-30 07:00:42
【问题描述】:
我有来自外部 postgresql 数据库的 ID 列表。
A = [1,2,3,4,5,6,7,98,0]
我会使用 SQLAlchemy 对数据库进行查询,但我会按 A 列表对 postgresql 中的数据进行排序。
我已阅读大量文档,但找不到任何建议。
所以,最后我会:
results = session.query(user).limit(20).offset(10).order_by(A)
干杯
更新:
我找到了解决方案,它没有我预期的那么好,但效果很好。无论如何,如果您知道更好的解决方案,请告诉我!
ids = ','.join([str(i) for i in A])
results = session.query(user).filter(user.id.in_(A)).\
limit(20).offset(10).\
order_by(" position(CONCAT(',',users.id::text,',') in ',{0},'.format(ids)")
【问题讨论】:
-
顺便说一句。我知道 postgresql 支持“连接值”stackoverflow.com/questions/866465/…,但无法弄清楚如何使用 sqlalchemy 实现这一点
-
我很好奇这样订购的原因,您介意详细说明吗?
标签: python sql postgresql sqlalchemy