1

我刚刚编写了以下查询并得到了一个(对我来说)惊喜的结果;

Customer.where("satisfaction != ?","Very satisfied")

这返回的值比我预期的要少得多,原因是我的满意度列的数据库中的空值。要获得我想要的记录,我必须编写以下查询

Customer.where("satisfaction != ? or satisfaction is null","Very satisfied")

这可行,但它很丑,我希望有更好的方法(特别是因为我计划动态生成这些查询,所以我希望它们尽可能简单)。是否存在将空值与不相等值结合在一起的运算符?

我的数据库是开发中的 SQLite3 和生产中的 Postgresql。

4

1 回答 1

5

在 PostgreSQL 中,您可以使用IS DISTINCT FROM来解决常见的 NULL 问题:

Customer.where('satisfaction is distinct from ?', 'Very satisfied')

在 SQLite 中,我认为您坚持使用显式 IS NULL 检查或同样丑陋的 COALESCE:

Customer.where("coalesce(satisfaction, '') != ?", 'Very satisfied')

COALESCE 计算为它的第一个非 NULL 参数,并且可以在 SQLite 和 PostgreSQL 中工作;您可以使用与您不匹配的任何内容来'Very satisfied'代替空字符串。

当您在 PostgreSQL 上进行部署时,我强烈建议您停止在 SQLite 上进行开发。当 SQLite 对 SQL 的松懈解释与 PostgreSQL 更严格的解释发生冲突时,您只是在生产服务器上要求一个糟糕的时间。不要对自己这样做,使用相同的数据库进行开发和部署(其中相同的包括版本号)。

您可能还想重新访问您的架构以查看是否可以将 NOT NULL 约束添加到您的satisfaction列。一个显式的'Unknown'字符串也可以起到同样的作用,并且可以避免通常的 NULL 废话。我倾向于手动将所有内容默认为 NOT NULL,并且仅在可以证明其合理性的情况下才允许使用 NULL。

于 2012-10-22T04:48:02.117 回答