在 MySQL 中修改 JSON 对象中的一部分值可以使用一些内置的 JSON 函数来实现。假设你有一个包含 JSON 数据的列,你可以使用 JSON_SET() 函数来更新其中的某个字段。
假设你有一个表 my_table,其中有一个 json_column 列包含 JSON 数据,示例数据如下:
{
"name": "John",
"age": 30,
"address": {
"city": "New York",
"state": "NY"
}
}
现在,假设你想更新 address 对象中的 city 字段为 “San Francisco”。你可以使用 JSON_SET() 函数来实现:
UPDATE my_table
SET json_column = JSON_SET(json_column, '$.address.city', 'San Francisco')
WHERE id = 1;
如果要更新的字段不存在,JSON_SET() 函数会自动创建它。
在举个例子,json如下:
{
"id": 1726768430132957191,
"col": 8,
"data": "",
"canSee": true,
"isValid": "Y",
"maxSize": 20,
"dataJson": null,
"dictType": "",
"disabled": false,
"formHide": true,
"isDelete": true,
"tenantId": 1702555882876141569,
"optionArr": [{
"label": "系统生成",
"value": "SYSTEM",
"showClose": null
}, {
"label": "通用模板",
"value": "MANUAL",
"showClose": null
}]
}
要更新 optionArr 数组中的一个元素的 label 字段。在 JSON 中,optionArr 是一个数组,因此你需要使用 JSON path 来指定要更新的具体元素。在 MySQL 中,数组的索引从0开始。
下面是更新语句需要进行的调整:
UPDATE lc_template_table
SET module_meta = JSON_SET(module_meta, '$.optionArr[0].label', '实验生成')
WHERE id = 1;
同时想将optionArr[1]…label 修改成“通用模板 ” 怎么修改呢
UPDATE lc_template_table
SET module_meta = JSON_SET(
JSON_SET(module_meta, '$.optionArr[0].label', '实验生成'),
'$.optionArr[1].label', '通用模板'
)
WHERE id = 1;
在这个更新语句中:
JSON_SET() 函数被嵌套使用。外部的 JSON_SET() 用来更新整体的 module_meta JSON 对象。
内部的 JSON_SET() 分别用来更新 optionArr 数组中的两个元素的 label 字段。
第一个 JSON_SET() 更新 optionArr[0].label 为 ‘实验生成’。
第二个 JSON_SET() 更新 optionArr[1].label 为 ‘通用模板’。
这样就可以一次性修改多个元素的值。记得根据实际情况调整数组元素的索引,确保更新到正确的位置。