金沙国际唯一官网网址SQL Server2015 原生补助JSON

如今也能在SQLServer2016中使用内置的JSON,那么应该是使用XML数据类型以及原生的函数,SQL Server 2005 开始支持 XML 数据类型,提供原生的 XML数据类型、XML,SQL Server 2005 开始支持 XML 数据类型,提供原生的 XML数据类型、XML

总结:

本篇通过对SQL二零一五 中的新扩大的停放JSON进行了回顾介绍,首要有如下要点:

 

  • JSON能在SQLServer贰零壹肆中火速的使用,但是JSON实际不是原生数据类型;
  • 假若利用JSON格式必得为出口结果是表明式的提供小名;
  • JSON_VALUE 和 JSON_QUEENCOREY 
    函数转移和获得Varchar格式的数据,由此必需将数据转译成你必要的连串。
  • 在妄想列的声援下询问JSON能够运用索引实行优化。

SQL Server二零一四 原生支持JSON

 

SQL Server 2006 早先帮忙 XML 数据类型,提供原生的 XML数据类型、XML
索引以及种种管理 XML 或输出 XML 格式的函数。

在 SQL Server 时隔 4
个第一版本
未来,终于在 Microsoft Ignite 2014大会上标准布告,新一代的 SQL Server 2014正式扶助未来最盛行的数据交换格式— JSON(JavaScript Object Notation)。

 

SQL Server 二零一五对JSON的帮忙并非增加贰个JSON数据类型,而是提供七个更轻易的框架,援救客商在数据Curry管理JSON格式数据。

客户无需更变现成的表结构,因为SQL Server使用NVARCHAENVISION数据类型来囤积JSON文件,并且跟现存技能并行相配,例如全文字笔迹核算索、列存款和储蓄索引、in-memory
OLTP,应用程序无需做其余修改

 

无需采用JSON.Net那类工具分析和拍卖JSON数据,利用SQL
Server内置函数就足以管理JSON数据,轻易将查询结构输出为JSON格式,可能搜索JSON文件内容。

 


使用 JSON AUTO 输出JSON 格式

要将select语句的结果以JSON输出,最简便的法子是在背后加上 FO奥德赛 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

借使想为FOCRUISER 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 二〇一四 CTP2
对于JSON的功用辅助依然比较有限,比方内置管理JSON格式化的函数,

ISJSON(决断是还是不是是JSON格式)、JSON_VALUE(深入分析JSON文件并提抽取值)
、OPENJSON(将JSON文件调换为平常数据表)

这个作用要等到CTP3手艺时有时无推出

 

越多SQL Server2014好用的效率,敬请期待o(∩_∩)o 

SQL Server二零一四 原生帮衬JSON

 

SQL Server 二零零六 初始援助 XML 数据类型,提供原生的 XML数据类型、XML
索引以及各个管理 XML 或输出 XML 格式的函数。

在 SQL Server 时隔 4
个根本版本
从此,终于在 Microsoft Ignite 2014大会上标准揭露,新一代的 SQL Server 2015正式协助未来最流行的数据交流格式— JSON(JavaScript Object Notation)。

 

SQL Server 二〇一四对JSON的支撑实际不是充实一个JSON数据类型,而是提供二个更轻易的框架,帮助客商在数据Curry管理JSON格式数据。

客户没有须求更变现存的表结构,因为SQL Server使用NVARCHALX570数据类型来积攒JSON文件,而且跟现存技艺并行协作,比如全文字笔迹查证索、列存款和储蓄索引、in-memory
OLTP,应用程序无需做别的改变

 

没有必要利用JSON.Net那类工具深入分析和拍卖JSON数据,利用SQL
Server内置函数就足以管理JSON数据,轻巧将查询结构输出为JSON格式,也许寻觅JSON文件内容。

 


使用 JSON AUTO 输出JSON 格式

要将select语句的结果以JSON输出,最简易的艺术是在后头加上 FO本田UR-V 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

假若想为FORAV4 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 2015 CTP2
对于JSON的功能接济依旧相比较有限,举例内置管理JSON格式化的函数,

ISJSON(判别是还是不是是JSON格式)、JSON_VALUE(解析JSON文件并提收取值)
、OPENJSON(将JSON文件转换为平日数据表)

那些成效要等到CTP3工夫陆陆续续推出

 

更加的多SQL Server二〇一五好用的效能,敬请期待o(∩_∩)o