Ada*_*ris 8 python sqlalchemy sql-order-by
我试图通过字段对SQLAlchemy ORM对象进行排序,但具有特定的值顺序(既不是升序也不是降序).如果我在MySQL上做这个查询,它看起来像;
SELECT letter FROM alphabet_table WHERE letter in ('g','a','c','k')
ORDER BY FIELDS( letter, 'g','a','c','k');
Run Code Online (Sandbox Code Playgroud)
输出:
letter
------
g
a
c
k
Run Code Online (Sandbox Code Playgroud)
对于SQLAlchemy,我一直在尝试以下方面:
session.query(AlphabetTable).filter(AlphabetTable.letter.in _(( 'G', 'A', 'C', 'K'))).ORDER_BY(AlphabetTable.letter.in _(( 'G','一", 'C', 'K')))
哪个不起作用......有什么想法吗?这是一个小的一次性常量列表,我可以创建一个包含订单的表然后加入,但这看起来有点太多了.
小智 12
sqlalchemy func表达式可用于生成order by field子句:
session.query(AlphabetTable) \
.filter(AlphabetTable.letter.in_("gack")) \
.order_by(sqlalchemy.func.field(AlphabetTable.letter, *"gack"))
Run Code Online (Sandbox Code Playgroud)
这可能不是一个非常令人满意的解决方案,但如何使用case表达式而不是order by fields:
sqlalchemy.orm.Query(AlphabetTable) \
.filter(AlphabetTable.letter.in_("gack")) \
.order_by(sqlalchemy.sql.expression.case(((AlphabetTable.letter == "g", 1),
(AlphabetTable.letter == "a", 2),
(AlphabetTable.letter == "c", 3),
(AlphabetTable.letter == "k", 4))))
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
5995 次 |
| 最近记录: |