有没有办法将 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');
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');