如何在 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 客户端在应用程序范围内可用?

在 Rails 范围内获取动态表别名

MySQL for Rails 在特定日期范围内每天获得 AVERAGE 的最佳方法

如何修复弃用警告:类级别方法将不再继承 Rails 6.1 中的范围?

Ruby on rails:仅从两列范围内获取数据

从 Rails 脚手架显示日期范围内的数据