在 MySQL 中,可以使用 JSON 函数来更新 json_type 数据
-
使用
JSON_SET()
函数更新 JSON 对象的值:UPDATE table_name SET json_column = JSON_SET(json_column, '$.key', 'new_value') WHERE condition;
其中,
table_name
是要更新的表名,json_column
是包含 JSON 数据的列名,$.key
是要更新的 JSON 对象的键,new_value
是新的值,condition
是更新条件。 -
使用
JSON_REPLACE()
函数更新 JSON 对象的值:UPDATE table_name SET json_column = JSON_REPLACE(json_column, '$.key', 'new_value') WHERE condition;
与
JSON_SET()
类似,JSON_REPLACE()
也可以用于更新 JSON 对象的值。不同之处在于,如果指定的键不存在,JSON_SET()
会创建一个新的键值对,而JSON_REPLACE()
不会。 -
使用
JSON_ARRAY_APPEND()
函数向 JSON 数组添加元素:UPDATE table_name SET json_column = JSON_ARRAY_APPEND(json_column, '$[index]', 'new_value') WHERE condition;
其中,
$[index]
是要添加元素的 JSON 数组的索引位置,new_value
是要添加的新元素。 -
使用
JSON_ARRAY_INSERT()
函数向 JSON 数组插入元素:UPDATE table_name SET json_column = JSON_ARRAY_INSERT(json_column, '$[index]', 'new_value') WHERE condition;
其中,
$[index]
是要插入元素的 JSON 数组的索引位置,new_value
是要插入的新元素。 -
使用
JSON_REMOVE()
函数删除 JSON 对象的键或 JSON 数组的元素:UPDATE table_name SET json_column = JSON_REMOVE(json_column, '$.key') WHERE condition;
其中,
$.key
是要删除的 JSON 对象的键。对于 JSON 数组,可以使用$[index]
表示要删除的元素的索引。
注意:在使用这些函数时,请确保提供正确的 JSON 路径和值,以避免意外地修改或删除数据。在更新生产环境中的数据之前,建议先在测试环境中进行验证。