微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

PHP Yii2中的PostgreSQL json选择查询替换

PHP Yii2中是否可以替换此查询

SELECT * FROM my_table在哪里my_column?& array [‘2′,’1′,’3′,’4’];

my_column = jsonb

因为我得到这个错误

Error Info: Array
(
  [0] => 42601
  [1] => 7
  [2] => ERROR:  Syntax error at or near "$1"
  LINE 1: SELECT * FROM my_table WHERE my_column $1& array['2', '1', '3',       '...
                                                 ^
)

我正在使用PHP Yii2和Postgresql 9.4:

$sql =“ SELECT * FROM my_table在哪里my_column?& array [‘2′,’1′,’3′,’4’];”;

$model = TestModel :: findBysql($sql)-> asArray()-> all();

查询的目的是比较数据库中是否存在该值.

数据库具有:

> [“ 1”,“ 2”,“ 3”,“ 4”]
> [“ 1”,“ 2”,“ 3”]

它可以在pgAdmin3 sql编辑器中使用.

PostgreSQL 9.41 jsonb Operators

解决方法:

在Postgresql中,是jsonb_exists()函数的别名. ?&是jsonb_exists_all()的别名.因此,您可以这样编写查询

SELECT * FROM my_table WHERE jsonb_exists_all('my_column', array['2', '1', '3', '4']);

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐