使用Postgres 9.0,我需要一种方法来测试给定数组中是否存在一个值。到目前为止,我想出了这样的东西:
select '{1,2,3}'::int[] @> (ARRAY[]::int[] || value_variable::int)
但我一直在想应该有更简单的方法,我就是不明白。这个似乎更好:
select '{1,2,3}'::int[] @> ARRAY[value_variable::int]
我相信这就足够了。但如果你有其他的方法,请分享!
使用Postgres 9.0,我需要一种方法来测试给定数组中是否存在一个值。到目前为止,我想出了这样的东西:
select '{1,2,3}'::int[] @> (ARRAY[]::int[] || value_variable::int)
但我一直在想应该有更简单的方法,我就是不明白。这个似乎更好:
select '{1,2,3}'::int[] @> ARRAY[value_variable::int]
我相信这就足够了。但如果你有其他的方法,请分享!
当前回答
Unnest也可以使用。 它将数组扩展为一组行,然后简单地检查一个值是否存在,就像使用IN或not IN一样简单。
如。
Id => uuid Exception_list_ids => uuid[]
select (exception (list_ids)) from table2
其他回答
小心我陷入的陷阱:当检查某个值是否不存在于数组中时,你不应该这样做:
SELECT value_variable != ANY('{1,2,3}'::int[])
但是使用
SELECT value_variable != ALL('{1,2,3}'::int[])
代替。
Unnest也可以使用。 它将数组扩展为一组行,然后简单地检查一个值是否存在,就像使用IN或not IN一样简单。
如。
Id => uuid Exception_list_ids => uuid[]
select (exception (list_ids)) from table2
ANY结构更简单:
SELECT value_variable = ANY ('{1,2,3}'::int[])
ANY的右操作数(括号之间)可以是一个集合(例如子查询的结果)或一个数组。有几种方法可以使用它:
如何过滤PgArray列类型? IN与PostgreSQL中的ANY运算符
重要区别:数组操作符(<@,@>,&&等)期望数组类型作为操作数,并在PostgreSQL的标准分布中支持GIN或GiST索引,而ANY构造期望元素类型作为左操作数,并且可以用普通b树索引支持(将索引表达式放在操作符的左边,而不是像你的例子中那样相反)。例子:
用于在JSON数组中查找元素的索引
这些都不适用于NULL元素。要测试NULL:
检查Postgres数组中是否存在NULL
在数组中查找元素是否存在时,需要适当的强制转换来传递postgres的SQL解析器。下面是一个在join子句中使用数组包含操作符的示例查询:
为了简单起见,我只列出了相关部分:
table1 other_name text[]; -- is an array of text
SQL的连接部分
from table1 t1 join table2 t2 on t1.other_name::text[] @> ARRAY[t2.panel::text]
以下也适用
on t2.panel = ANY(t1.other_name)
我只是猜测需要额外的强制转换,因为解析不必获取表定义来确定列的确切类型。请其他人对此发表评论。
嗨,这个对我来说很好,也许对别人有用
select * from your_table where array_column ::text ilike ANY (ARRAY['%text_to_search%'::text]);