有没有办法将 JSON 字段的数组与 MySQL 中的 JSON_ARRAY 进行比较?

Is there a way how to compare array from JSON field against JSON_ARRAY in MySQL?

MySQL table contacts

我有一个JSON类型的栏目responses,内容是

{"1": ["Yes", "No", "Maybe"], "2": ["Yes"], "3": ""}

我想知道是否可以在 SELECT 语句 -> WHERE 子句中找出​​第一个 JSON 元素是否与某个给定数组相等(它会改变)。

我的想法是这样的:

WHERE contacts.responses->>'$."1"' = JSON_ARRAY('Yes','No','Maybe')

但这不起作用(即使当两个比较边都包含在 SELECT 语句中时,它们显示相同 - '["Yes", "No", "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", "Maybe"], "2": ["Yes"], "3": ""}');
INSERT INTO t1 VALUES('{"1": ["Yes", "Maybe"], "2": ["Yes"], "3": ""}');

select jdoc from t1 where JSON_EXTRACT(jdoc,'$."1"') = JSON_ARRAY('Yes','No','Maybe');