首页 >数据库 >mysql教程 >我应该在 PostgreSQL WHERE 子句中使用 IN 还是 ANY?

我应该在 PostgreSQL WHERE 子句中使用 IN 还是 ANY?

DDD
DDD原创
2025-01-14 20:42:48920浏览

Should I Use IN or ANY in PostgreSQL WHERE Clauses?

在 WHERE 子句中使用 ANY 代替 IN

在传统的 IN 子句之外,您可以考虑使用 ANY 来过滤 WHERE 子句中的结果。 PostgreSQL 提供了两种语法变体:

IN 表达式:

  • expression IN (subquery)
  • expression IN (value [, ...])

ANY 表达式:

  • expression operator ANY (subquery)
  • expression operator ANY (array expression)

虽然两种方法都可以使用子查询,但它们的第二种形式在预期方面有所不同。

如何选择?

考虑以下几点:

  • ANY 提供更大的灵活性,并且可以与任何返回布尔值的二元运算符一起使用。
  • IN 是 ANY 的特例,其操作方式类似于 = ANY。

在性能方面,ANY 不太可能比 IN 显着快。两者之间的选择主要取决于提供筛选值的便捷性。

子查询方法:

如果筛选值已经存在于数据库中,使用子查询或将源表与目标表连接可以提高效率。

数组方法:

为了获得最佳性能,可以通过数组、unnest() 或连接,或者使用 VALUES 提供表表达式来从客户端提供大量的数值。

= ANY 的语法:

对于数组表达式,PostgreSQL 接受数组构造器 (ARRAY[1,2,3]) 或数组字面量 ('{1,2,3}')。为了类型安全,可以使用显式类型转换:

<code class="language-sql">ARRAY[1,2,3]::numeric[]
'{1,2,3}'::bigint[]</code>

从 Ruby 传递数组:

要从 Ruby 传递数组,请使用以下语法:

<code class="language-ruby">MyModel.where('id = ANY(ARRAY[?]::int[])', ids.map { |i| i})</code>

以上是我应该在 PostgreSQL WHERE 子句中使用 IN 还是 ANY?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn