SQLAlchemy ORDER BY FIELD()

时间:2011-09-16 10:18:24

标签: 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');

输出:

letter
------
  g
  a
  c
  k

对于SQLAlchemy,我一直在尝试以下方面:

session.query(AlphabetTable).filter(AlphabetTable.letter.in _(( 'G', 'A', 'C', 'K')))。ORDER_BY(AlphabetTable.letter.in _(( 'G' , 'A', 'C', 'K')))

哪个不起作用......有什么想法吗?这是一个小的一次性常量列表,我可以创建一个包含订单的表然后加入,但这看起来有点太多了。

2 个答案:

答案 0 :(得分:12)

sqlalchemy func expression可用于生成order by field子句:

session.query(AlphabetTable) \
    .filter(AlphabetTable.letter.in_("gack")) \
    .order_by(sqlalchemy.func.field(AlphabetTable.letter, *"gack"))

答案 1 :(得分:7)

这可能不是一个非常令人满意的解决方案,但如何使用case expression代替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))))