如何解决有没有一种方法如何将JSON字段中的数组与MySQL中的JSON_ARRAY进行比较?
MySQL表contacts
我有一个JSON类型列responses
,其内容是
{"1": ["Yes","No","Maybe"],"2": ["Yes"],"3": ""}
我想知道是否有可能在SELECT语句-> WHERE子句中找到第一个JSON元素是否与某个给定数组相等(它将改变)。
我的想法是这样的:
WHERE contacts.responses->>'$."1"' = JSON_ARRAY('Yes','No','Maybe')
,但这不起作用(即使当SELECT语句中包含两个比较侧时,它们同样显示-'["Yes","Maybe"]'
)。那么,还有其他方法可以做到这一点吗?
解决方法
您可以在Mysql 8 The JSON Data Type
中使用很多功能您可以使用JSON_EXTRACT从列中的json中提取数据。您在问题中输入的数据是对象,您必须使用$."1"
进行指向。注意必须使用$[1]
的数组。
以下是您的数据和可能的输出示例。
CREATE TABLE t1 (jdoc JSON);
INSERT INTO t1 VALUES('{"1": ["Yes","No","Maybe"],"2": ["Yes"],"3": ""}');
INSERT INTO t1 VALUES('{"1": ["YY","XX","3": ""}');
INSERT INTO t1 VALUES('{"1": ["Yes","3": ""}');
select jdoc from t1 where JSON_EXTRACT(jdoc,'$."1"') = JSON_ARRAY('Yes','No','Maybe');
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。