SQL Server 2005开始支持XML数据类型,提供原生的XML数据类型、XML索引及各种管理或输出XML格式的函数。随着JSON的流行,SQL Server2016开始支持JSON数据类型,不仅可以直接输出JSON格式的结果集,还能读取JSON格式的数据。

下面是我们熟悉的SELECT及输出格式,后面对JSON的演示基于此SQL:

一、 将查询结果输出JSON格式

1、FOR JSON AUTO:SELECT语句的结果以JSON输出。

要将SELECT语句的结果以JSON输出,最简单的方法是在后面加上FOR JSON AUTO:

2、FOR JSON AUTO,Root(’’) :为JOSN加上根节点

若要为FOR JSON加上Root Key,可以用ROOT选项来自定义ROOT 节点的名称:

3、FOR JSON PATH输出:可通过列别名来定义JSON对象的层次结构

若要自定义输出JSON格式的结构时,必须使用JSONPATH。

  • FOR JSON Auto,自动按照查询语句中使用的表结构来创建嵌套的JSON子数组,类似于For Xml Auto特性。
  • FOR JSON Path,通过列名或者列别名来定义JSON对象的层次结构,列别名中可以包含“.”,JSON的成员层次结构将会与别名中的层次结构保持一致。
    这个特性非常类似于早期SQL Server版本中的For Xml Path子句,可以使用斜线来定义xml的层次结构。

4、FOR JSON PATH+ROOT输出:为JOSN加上根节点

5、INCLUDE_NULL_VALUES:值null的字段需要显示出现。

为NULL的数据在输出JSON时,会被忽略,若想要让NULL的字段也显示出来,可以加上选项INCLUDE_NULL_VALUES,该选项也适用于AUTO。

6、列的别名,可以增加带有层级关系的节点。

比如下面的SQL,增加了一个“SN”节点,把栏位SERNUM和CLIMAT放在里面:

二、 解析JSON格式的数据

1、使用OPENJSON()函数:

2、通过WITH选项,自定义输出列:

三、JSON函数

declare @param nvarchar(max);

set @param = N'{
"info":{
"type":1,
"address":{
"town":"Bristol",
"county":"Avon",
"country":"England"
},
"tags":["Sport", "Water polo"]
},
"type":"Basic"
}';

1、ISJSON:测试字符串是否包含有效 JSON。

print iif(isjson(@param) > 0, 'OK', 'NO');

返回:OK

2、JSON_VALUE :从 JSON 字符串中提取标量值。

print json_value(@param, '$.info.address.town');
print json_value(@param, '$.info.tags[1]');

返回:Bristol,Water polo

3、JSON_QUERY :从 JSON 字符串中提取对象或数组。

print json_query(@param, '$.info');
{
"type":1,
"address":{
"town":"Bristol",
"county":"Avon",
"country":"England"
},
"tags":["Sport", "Water polo"]
}

4、JSON_MODIFY :更新 JSON 字符串中属性的值,并返回已更新的 JSON 字符串。

print json_modify(@param, '$.info.address.town', 'London');

返回:

{
"info":{
"type":1,
"address":{
"town":"London",
"county":"Avon",
"country":"England"
},
"tags":["Sport", "Water polo"]
},
"type":"Basic"
}

四、注意事项

SQL2016 中的新增的内置JSON进行了简单介绍,主要有如下要点:

  • JSON能在SQLServer2016中高效的使用,但是JSON并不是原生数据类型;
  • 如果使用JSON格式必须为输出结果是表达式的提供别名;
  • JSON_VALUE 和 JSON_QUERY  函数转移和获取Varchar格式的数据,因此必须将数据转译成你需要的类型。
  • 在计算列的帮助下查询JSON可以使用索引进行优化。

最新文章

  1. (系统架构)标准Web系统的架构分层
  2. UIkit – 轻量级前端框架,帮助你快速构建 Web 界面
  3. iOS 获取emoji表情和拦截emoji表情
  4. 如何设置一个严格30分钟过期的Session(转载)
  5. VS2010 刷新工具箱(刷新自定义控件)
  6. Bootstrap兼容
  7. 慕课网-安卓工程师初养成-2-5 如何命名Java变量
  8. leetcode面试准备:Add and Search Word - Data structure design
  9. VCRedist.exe静默安装方法(转)
  10. android 控制手机的体积的大小 切换音效模式
  11. 笔记整理:计算CPU使用率 ----linux 环境编程 从应用到内核
  12. bootstrap-实现loading效果
  13. STL 标准模板库
  14. 10分钟看懂!基于Zookeeper的分布式锁
  15. Codeforces 946 D.Timetable-数据处理+动态规划(分组背包) 处理炸裂
  16. python-单元测试unittest
  17. Unity攻击敌人时产生泛白效果
  18. Neuron network
  19. 解决Eclipse中文乱码的问题
  20. Linux中shell变量$0,$?等含义

热门文章

  1. C# using用法
  2. Linux man C++ 库函数
  3. hadoop学习笔记(六):HDFS文件的读写流程
  4. 脚手架(create-react-app)没有eject情况下,使用react-scripts的时候,动态设置环境变量
  5. AspxGridView中行的双击事件
  6. WPF 从文件加载字体
  7. AE开发流程
  8. C# linq to xml 简单示例
  9. C# 分页方法
  10. [日常] json_encode对中文和引号的处理差异研究