如何在MySQL 5.7.10中更新JSON数据类型列?
我最近开始使用MySQL 5.7.10,我非常喜欢原生JSON数据类型 但在更新JSON类型值时,我遇到了一个问题 问题: 下面是表格格式,我想在JSON如何在MySQL 5.7.10中更新JSON数据类型列?,mysql,json,mysql-5.7,mysql-json,Mysql,Json,Mysql 5.7,Mysql Json,我最近开始使用MySQL 5.7.10,我非常喜欢原生JSON数据类型 但在更新JSON类型值时,我遇到了一个问题 问题: 下面是表格格式,我想在JSONdata列中为t1表格添加1个键。现在我必须获取值,修改它并更新表。因此,它涉及一个额外的SELECT语句 我可以这样插入 INSERT INTO t1 values ('{"key2":"value2"}', 1); mysql> select * from t1; +--------------------+------+ | da
data
列中为t1
表格添加1个键。现在我必须获取值,修改它并更新表。因此,它涉及一个额外的SELECT
语句
我可以这样插入
INSERT INTO t1 values ('{"key2":"value2"}', 1);
mysql> select * from t1;
+--------------------+------+
| data | id |
+--------------------+------+
| {"key1": "value1"} | 1 |
| {"key2": "value2"} | 2 |
| {"key2": "value2"} | 1 |
+--------------------+------+
3 rows in set (0.00 sec)
mysql>Show create table t1;
+-------+-------------------------------------------------------------
-------------------------------------------------------+
| Table | Create Table |
+-------+--------------------------------------------------------------------------------------------------------------------+
| t1 | CREATE TABLE `t1` (
`data` json DEFAULT NULL,
`id` int(11) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=latin1 |
+-------+--------------------------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)
有什么解决办法吗?谢谢@wchiquito为我指明了正确的方向。我解决了这个问题。我是这样做的
mysql> select * from t1;
+----------------------------------------+------+
| data | id |
+----------------------------------------+------+
| {"key1": "value1", "key2": "VALUE2"} | 1 |
| {"key2": "VALUE2"} | 2 |
| {"key2": "VALUE2"} | 1 |
| {"a": "x", "b": "y", "key2": "VALUE2"} | 1 |
+----------------------------------------+------+
4 rows in set (0.00 sec)
mysql> update t1 set data = JSON_SET(data, "$.key2", "I am ID2") where id = 2;
Query OK, 1 row affected (0.04 sec)
Rows matched: 1 Changed: 1 Warnings: 0
mysql> select * from t1;
+----------------------------------------+------+
| data | id |
+----------------------------------------+------+
| {"key1": "value1", "key2": "VALUE2"} | 1 |
| {"key2": "I am ID2"} | 2 |
| {"key2": "VALUE2"} | 1 |
| {"a": "x", "b": "y", "key2": "VALUE2"} | 1 |
+----------------------------------------+------+
4 rows in set (0.00 sec)
mysql> update t1 set data = JSON_SET(data, "$.key3", "I am ID3") where id = 2;
Query OK, 1 row affected (0.07 sec)
Rows matched: 1 Changed: 1 Warnings: 0
mysql> select * from t1;
+------------------------------------------+------+
| data | id |
+------------------------------------------+------+
| {"key1": "value1", "key2": "VALUE2"} | 1 |
| {"key2": "I am ID2", "key3": "I am ID3"} | 2 |
| {"key2": "VALUE2"} | 1 |
| {"a": "x", "b": "y", "key2": "VALUE2"} | 1 |
+------------------------------------------+------+
4 rows in set (0.00 sec)
编辑: 如果要添加数组,请使用
JSON\u array
like
update t1 set data = JSON_SET(data, "$.key4", JSON_ARRAY('Hello','World!')) where id = 2;
现在使用MySQL 5.7.22+,在一个查询中更新整个json片段(多个键值,甚至嵌套)非常简单明了,如下所示:
update t1 set data =
JSON_MERGE_PATCH(`data`, '{"key2": "I am ID2", "key3": "I am ID3"}') where id = 2;
希望它能帮助访问此页面并寻找“更好”的JSON集的人
有关JSON\u MERGE\u补丁的更多信息,请点击此处:
为什么要添加这样的数据?它应该是键和值的单独列。@PathikVejani就像我提到的,我正在尝试使用mysql 5.7,它提供本机json数据类型。我的JSON可能很大。我无法为每个键值对添加列。请检查:。@wchiquito感谢您为我指明了正确的方向。我已经发布了我的解决方案,不过所有的功劳都应该归于你。这个链接很有用的好消息。这个更新对于单个“key:value”来说效果很好。那么如何更新多个键值?……像这样的@siva-JSON_集(@j,'$.key1',10,'$.key2','[true,false]'))如果我想要“$(:passedData)”中的键如何?我想根据从客户端获得的值更新密钥,似乎我无法通过:passedData传递任何值