我在 postgres 中有一个表,其中有一value
列包含字符串数组。我的目标是找到包含以下任何字符串的所有数组: {'cat', 'dog'}
id value
1 {'dog', 'cat', 'fish'}
2 {'elephant', 'mouse'}
3 {'lizard', 'dog', 'parrot'}
4 {'bear', 'bird', 'cat'}
以下查询用于ANY()
检查 'dog' 是否等于每个数组中的任何项,并将正确返回第 1 行和第 3 行:
select * from mytable where 'dog'=ANY(value);
我正在尝试找到一种方法来搜索value
字符串数组中的任何匹配项。例如 :
select * from mytable where ANY({'dog', 'cat'})=ANY(value);
应该返回第 1、3 和 4 行。但是,上面的代码会引发错误。有没有办法在这个等式的左边使用 ANY() 子句?如果没有,检查数组中是否有任何字符串的解决方法是value
什么?