Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/json/14.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
如何在MySQL 5.7.10中更新JSON数据类型列?_Mysql_Json_Mysql 5.7_Mysql Json - Fatal编程技术网

如何在MySQL 5.7.10中更新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

我最近开始使用MySQL 5.7.10,我非常喜欢原生JSON数据类型

但在更新JSON类型值时,我遇到了一个问题

问题:

下面是表格格式,我想在JSON
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传递任何值