在 WHERE 子句中使用 ANY 代替 IN
在传统的 IN 子句之外,您可以考虑使用 ANY 来过滤 WHERE 子句中的结果。 PostgreSQL 提供了两种语法变体:
IN 表达式:
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中文网其他相关文章!