随笔 - 836  文章 - 1 评论 - 40 阅读 - 102万
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

参考:http://www.lnmp.cn/mysql-57-new-features-json.html


方式一: 可以查到json中的Key:value

 

 

SELECT * FROM EDI.edi_history WHERE JSON_CONTAINS(response_summary, json_array(json_object("orderNo","10007"))) 
and JSON_CONTAINS(response_summary,  json_array(json_object("courierCompanyCode","Air21")))

and JSON_CONTAINS(response_summary,  json_array(json_object("dataSource", "EDI_AFTERSHIP")))

and JSON_CONTAINS(response_summary,  json_array(json_object("courierBillNo","888888")))

 

方式2:   仅仅通过包含:

 
select * from EDI.edi_history  where json_contains(response_summary, '{"dest_stn":"PRQ"}')

 

 

 

只更新部分值:

 

UPDATE EDI.edi_history SET response_summary = JSON_REPLACE(response_summary, '$.result', 'php') WHERE id = 1;

 

 

创建表

CREATE TABLE t_json(id INT PRIMARY KEYNAME VARCHAR(20) , info  JSON);
 
插入记录
INSERT INTO t_json(id,sname,info) VALUES(1 ,'test','{"time":"2017-01-01 13:00:00","ip":"192.168.1.1","result":"fail"}');
INSERT INTO t_json(id,sname,info)  VALUES(2 ,'my',JSON_OBJECT("time",NOW(),'ip','192.168.1.1','result','fail'));
 
查询IP键
SELECT sname,JSON_EXTRACT(info,'$.ip'FROM t_json;
查询有多少个键
SELECT id,json_keys(info) AS "keys" FROM t_json;
 
 
删除键
UPDATE t_json SET info = json_remove(info,'$.ip');
增加键
UPDATE t_json SET info = json_set(info,'$.ip','192.168.1.1');
变更值
UPDATE t_json SET info = json_set(info,'$.ip','192.168.1.2');
posted on   lshan  阅读(6708)  评论(2编辑  收藏  举报
编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
点击右上角即可分享
微信分享提示