SQLAlchemy ORDER BY FIELD()

这篇博客探讨了如何在SQLAlchemy ORM中实现类似于MySQL的FIELD函数排序,通过Case表达式和func.field方法来定制排序顺序。示例展示了如何根据特定值顺序对查询结果进行排序,这在处理自定义排序需求时非常有用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

如下:

query = query.order_by(
            func.field(VpFaces.sex_id, 2, 1),
            VpFaces.region_id.asc(),
            VpFaces.age_id.asc(),
            VpFaces.id.asc()
        )

按字段对SQLAlchemy ORM对象进行排序,但使用特定的值顺序(既不升序也不降序)。如果我在MySQL上做这个查询,它看起来像

SELECT letter FROM alphabet_table WHERE letter in ('g','a','c','k')
ORDER BY FIELDS( 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'))
)

# Answer 1
This may not be a very satisfying solution, but how about using a case expression instead of 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))))


# Answer 2
A sqlalchemy func expression can be used to generate the order by field clause:

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值