如何在 Rails 范围内模拟 Postgresql EXCEPT 运算符?
Posted
技术标签:
【中文标题】如何在 Rails 范围内模拟 Postgresql EXCEPT 运算符?【英文标题】:How to emulate Postgresql EXCEPT operator in rails scope? 【发布时间】:2022-01-12 06:35:40 【问题描述】:我有一个 SQL 查询
SELECT * FROM students
EXCEPT
SELECT * FROM students WHERE val->>'rating' = 'Fail'
如何在 Rails 范围内实现相同的结果?
【问题讨论】:
您可以将其重写为where not exists
条件。也许你的混淆层可以处理。
SELECT * FROM students WHERE val->>'rating' <> 'Fail'
@Edouard 这个查询不适合我。这和我指定的不一样。我还需要不存在评级键的记录。
@Alex Shmatko:好的,让我们试试这个:SELECT * FROM students WHERE val->>'rating' IS DISTINCT FROM 'Fail'
,这个查询应该包括不存在'rating'键的记录
@Edouard 好东西!谢谢!
【参考方案1】:
SELECT * FROM students
EXCEPT
SELECT * FROM students WHERE val->>'rating' = 'Fail'
等于
Student.where("val->>'rating' IS DISTINCT FROM ?", 'Fail')
【讨论】:
以上是关于如何在 Rails 范围内模拟 Postgresql EXCEPT 运算符?的主要内容,如果未能解决你的问题,请参考以下文章
如何使 ElasticSearch 客户端在应用程序范围内可用?
MySQL for Rails 在特定日期范围内每天获得 AVERAGE 的最佳方法