sql server2016里面的json功能怎么使用
发表于:2025-11-07 作者:千家信息网编辑
千家信息网最后更新 2025年11月07日,这篇文章主要介绍"sql server2016里面的json功能怎么使用",在日常操作中,相信很多人在sql server2016里面的json功能怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简
千家信息网最后更新 2025年11月07日sql server2016里面的json功能怎么使用
这篇文章主要介绍"sql server2016里面的json功能怎么使用",在日常操作中,相信很多人在sql server2016里面的json功能怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"sql server2016里面的json功能怎么使用"的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
测试一下基本的,从查询结果里面构造一个json 的格式
create table t1(ID int identity,name nvarchar(50),Chinese int ,Math int)insert into t1 values ('张三',90,80),('李四',75,90),('王五',68,100)select * from t1select * from t1 for json auto--查询结果ID name Chinese Math----------- -------------------------------------------------- ----------- -----------1 张三 90 802 李四 75 903 王五 68 100--json 格式[{"ID":1,"name":"张三","Chinese":90,"Math":80},{"ID":2,"name":"李四","Chinese":75,"Math":90},{"ID":3,"name":"王五","Chinese":68,"Math":100}]这个是默认模式下面使用json的查询结果。是不是十分清晰
然后我们再接再厉,第二波是这样纸的。假如我们要继续搞有层级关系的。我们还可以这样写。比方说把成绩放在一个叫points 的节点里面, 也是可以分层的
select ID, name, Chinese as [Points.Chinese], Math as [Points.Math] from t1 for json path--结果json[{"ID":1,"name":"张三","Points":{"Chinese":90,"Math":80}},{"ID":2,"name":"李四","Points":{"Chinese":75,"Math":90}},{"ID":3,"name":"王五","Points":{"Chinese":68,"Math":100}}]他们的分数就放在了json 里面的,被一个point 包住了。
如果说我要在这个结果里面添加一个头来包住,当然,我可以使用每个列来个别名 [root.col] 来实现,然而就有点啰嗦了。所以我们可以使用这个root 的关键字来添加一个顶节点
select ID, name, Chinese as [Points.Chinese], Math as [Points.Math] from t1 for json path,root('root') --返回的json结果{"root":[ {"ID":1,"name":"张三","Points":{"Chinese":90,"Math":80}}, {"ID":2,"name":"李四","Points":{"Chinese":75,"Math":90}},{"ID":3,"name":"王五","Points":{"Chinese":68,"Math":100}}]}当然咯,查询嘛,录入数据总是难免遇到null值,在这方面,for json 是如何处理的呢? 我在测试表添加一条数据在来查询
insert into t1 values ('赵六',100,null)select ID, name, Chinese as [Points.Chinese], Math as [Points.Math] from t1 where id in(3, 4) for json auto--json的返回结果[{"ID":3,"name":"王五","Points.Chinese":68,"Points.Math":100},{"ID":4,"name":"赵六","Points.Chinese":100}]auto 模式下,如果是空值,将会忽略该属性。这样的话很容易就每一个集合返回的属性数量都不一来,这样不好看。所以应对这种情况,我们可以使用 incluede_null_values 关键字,即使是空值,也带出来
select ID, name, Chinese as [Points.Chinese], Math as [Points.Math] from t1 where id in(3, 4) for json auto, include_null_values--json 的返回结果[{"ID":3,"name":"王五","Points.Chinese":68,"Points.Math":100},{"ID":4,"name":"赵六","Points.Chinese":100,"Points.Math":null}]使用了这个关键字,就可以把空值带出来,里面的值是Null 值
到此,关于"sql server2016里面的json功能怎么使用"的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注网站,小编会继续努力为大家带来更多实用的文章!
结果
王五
张三
李四
查询
功能
学习
关键
关键字
属性
数据
更多
格式
模式
节点
加一
帮助
测试
实用
再接再厉
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
拼音输入法数据库
服务器内存模块电路
河北网络电视时间服务器异常
网络安全政策与法律心得
做网站属于软件开发吗
江苏gps网络时钟服务器价格
如何加强web服务器的安全
数据包分析网络技术
服务器可以加装hdmi接口吗
搭建个人塔式服务器
四川手机软件开发要多少钱
ftp服务器 编写
移动通信网络技术pdf
中标麒麟服务器版多少钱
闪耀暖暖一区服务器全名
ponytown安全服务器
2022希望之村服务器没了
芦芦游戏解说服务器是啥
纬度在线北京网络技术
上海网信办 网络技术处
千年服务器管理工具
信阳系统软件开发
赣县区网络安全大队
魔兽世界7区各服务器联盟比例
重庆建筑软件开发公司
吴两全网络技术服务部是干嘛
县区网络安全督查通报
安装数据库实例名称
网络安全对世界各国的重要性
油井数据库泄密