原生支持JSON,函数详解

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

1   概述

SQL Server2016 原生支持JSON

 

SQL Server 2005 开始支持 XML 数据类型,提供原生的 XML数据类型、XML
索引以及各种管理 XML 或输出 XML 格式的函数。

在 SQL Server 时隔 4
个主要版本
之后,终于在 Microsoft Ignite 2015
大会上正式宣布,新一代的 SQL Server 2016
正式支持现在最流行的数据交换格式— JSON(JavaScript Object Notation)。

 

SQL Server 2016
对JSON的支持并不是增加一个JSON数据类型,而是提供一个更轻便的框架,帮助用户在数据库里处理JSON格式数据。

用户不需要更变现有的表结构,因为SQL Server使用NVARCHAR
数据类型来存储JSON文件,并且跟现有技术相互兼容,比如全文搜索、列存储索引、in-memory
OLTP,应用程序不需要做任何修改

 

不需要使用JSON.Net这类工具分析和处理JSON数据,利用SQL
Server内置函数就可以处理JSON数据,轻松将查询结构输出为JSON格式,或者搜索JSON文件内容。

 


使用 JSON AUTO 输出JSON 格式

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

测试版本

Microsoft SQL Server 2016 (CTP2.2) - 13.0.407.1 (X64)   Jul 22 2015 21:19:11   Copyright (c) Microsoft Corporation  Enterprise Evaluation Edition (64-bit) on Windows Server 2012 R2 Standard 6.3 <X64> (Build 9600: ) (Hypervisor) 

SELECT * FROM [dbo].[Client] 
GO

SELECT * FROM [dbo].[Client] FOR JSON AUTO
GO

 

图片 1

 

我们可以把每列中显示的最大字符数 设置为8192

图片 2

图片 3

 


加上Root Key

如果想为FOR JSON 加上Root Key,可以使用ROOT选项来指定 Root Key 名称

SELECT * FROM [dbo].[Client] FOR JSON AUTO,ROOT('SUSU')
GO

图片 4

 


使用JSON PATH 输出JSON格式

当想要自定义输出JSON格式结构的时候,必须用JSON PATH描述,若SELECT
的字段名称相同,必须用别名方式来重新命名字段名这样才可以继续查询

另外,如果字段的默认值为NULL,那么输出JSON时,JSON会忽略null的只。如果要显示null值,可以加上INCLUDE_NULL_VALUES
选项(同样适用于JSON AUTO字句)

select * from  [dbo].[Client]

--FOR JSON PATH
SELECT * FROM [dbo].[Client] WHERE ClientID =2
FOR JSON PATH

[{"ClientID":2,"Firstname":"Peter","Lastname":"Nielsen","Birthdate":"1998-05-19T00:00:00","Email":"Peter@126.com","PhoneNumber":"+86-16326269674","Birthplace":"Stockholm","SocialSecurityNumber":"1901531234"}]

--FOR JSON PATH
SELECT * FROM [dbo].[Client] WHERE ClientID =4
FOR JSON PATH,INCLUDE_NULL_VALUES

[{"ClientID":4,"Firstname":"kade","Lastname":null,"Birthdate":"1980-01-06T00:00:00","Email":"Lotte@SOHU.com","PhoneNumber":"+86-16326269674","Birthplace":"Aalborg","SocialSecurityNumber":"1061234"}]

图片 5

 

 

更多关于JSON的功能

目前SQL Server 2016 CTP2
对于JSON的功能支持还是比较有限,例如内置处理JSON格式化的函数,

ISJSON(判断是否是JSON格式)、JSON_VALUE(分析JSON文件并提取出值)
、OPENJSON(将JSON文件转换为普通数据表)

这些功能要等到CTP3才能陆续推出

 

更多SQL Server2016好用的功能,敬请期待o(∩_∩)o 

1 概述

 本篇文件将结合MSND简要分析Sqlserver中JSON函数,主要包括ISJSON,JSON_VALUE,JSON_MODIFY,JSON_QUERY。

本篇文件将结合MSND简要分析Sqlserver中JSON函数,主要包括ISJSON,JSON_VALUE,JSON_MODIFY,JSON_QUERY。

2   具体内容

2 具体内容

2.1  JSON 函数

2.1 JSON 函数

使用本节中页面中描述的功能来验证或更改JSON文本或提取简单或复杂的值。

使用本节中页面中描述的功能来验证或更改JSON文本或提取简单或复杂的值。

图片 6

有关在SQL Server中内置JSON支持的更多信息,请参阅JSON数据。

有关在SQL Server中内置JSON支持的更多信息,请参阅JSON数据(SQL
Server)。

2.2 ISJSON

2.2  ISJSON

测试字符串是否包含有效的JSON。

测试字符串是否包含有效的JSON。

2.2.1 例子

图片 7

2.3 JSON_VALUE

 

从JSON字符串中提取标量值。

2.2.1  例子

要从JSON字符串而不是标量值中提取对象或数组,请参阅JSON_QUERY。有关JSON_VALUE和JSON_QUERY之间的差异的信息,请参阅比较JSON_VALUE和JSON_QUERY。

图片 8

2.4 JSON_QUERY

图片 9

从JSON字符串中提取对象或数组。

2.3  JSON_VALUE

要从JSON字符串而不是对象或数组中提取标量值,请参阅JSON_VALUE。有关JSON_VALUE和JSON_QUERY之间的差异的信息,请参阅比较JSON_VALUE和JSON_QUERY。

从JSON字符串中提取标量值。

2.5 JSON_MODIFY

要从JSON字符串而不是标量值中提取对象或数组,请参阅JSON_QUERY(Transact-SQL)。有关JSON_VALUE和JSON_QUERY之间的差异的信息,请参阅比较JSON_VALUE和JSON_QUERY。

更新JSON字符串中的属性值,并返回更新的JSON字符串。

图片 10

小结

图片 11

3 参考文献

 

4 版权

 图片 12

感谢您的阅读,若有不足之处,欢迎指教,共同学习、共同进步。

 

以下是一些补充

2.4  JSON_QUERY

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

从JSON字符串中提取对象或数组。

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

要从JSON字符串而不是对象或数组中提取标量值,请参阅JSON_VALUE(Transact-SQL)。有关JSON_VALUE和JSON_QUERY之间的差异的信息,请参阅比较JSON_VALUE和JSON_QUERY。

3、FOR JSON
PATH输出:可通过列别名来定义JSON对象的层次结构若要自定义输出JSON格式的结构时,必须使用JSONPATH。

 图片 13

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

图片 14

这个特性非常类似于早期SQL Server版本中的For Xml
Path子句,可以使用斜线来定义xml的层次结构。

 

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

 2.5  JSON_MODIFY

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

更新JSON字符串中的属性值,并返回更新的JSON字符串。

6、列的别名,可以增加带有层级关系的节点。比如下面的SQL,增加了一个“SN”节点,把栏位SERNUM和CLIMAT放在里面:

 图片 15

二、 解析JSON格式的数据

图片 16

1、使用OPENJSON()函数:

图片 17

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

小结

三、JSON函数

图片 18

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

3   参考文献

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

 【01】

print iif(isjson(@param) 0, ‘OK’, ‘NO’);

4   版权

返回:OK

 

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

  • 感谢您的阅读,若有不足之处,欢迎指教,共同学习、共同进步。
  • 博主网址:
  • 极少部分文章利用读书、参考、引用、抄袭、复制和粘贴等多种方式整合而成的,大部分为原创。
  • 如您喜欢,麻烦推荐一下;如您有新想法,欢迎提出,邮箱:2016177728@qq.com。
  • 可以转载该博客,但必须著名博客来源。

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可以使用索引进行优化。

好了这篇文章就介绍到这了,需要的朋友可以参考一下。

发表评论

电子邮件地址不会被公开。 必填项已用*标注