SQL Server201陆 原生匡助JSON

SQL Server201陆 原生匡助JSON

总结:

本篇通过对SQL201陆 中的新增的嵌入JSON举行了简要介绍,主要有如下要点:

 

  • JSON能在SQLServer二零一四中快速的使用,不过JSON并不是原生数据类型;
  • 若果选拔JSON格式必须为出口结果是表达式的提供小名;
  • JSON_VALUE 和 JSON_QUEPRADOY 
    函数转移和获得Varchar格式的数据,由此必须将数据转译成你需求的连串。
  • 在盘算列的声援下询问JSON能够动用索引实行优化。

总结:

本篇通过对SQL2016 中的新增的放置JSON举行了容易介绍,首要有如下要点:

 

  • JSON能在SQLServer201陆中飞快的行使,然而JSON并不是原生数据类型;
  • 假诺利用JSON格式必须为出口结果是表明式的提供别名;
  • JSON_VALUE 和 JSON_QUEXC90Y 
    函数转移和获取Varchar格式的数据,由此必须将数据转译成你须求的门类。
  • 在盘算列的帮手下询问JSON能够选拔索引进行优化。

SQL Server201六 原生支持JSON

 

SQL Server 200五 伊始援救 XML 数据类型,提供原生的 XML数据类型、XML
索引以及各类管理 XML 或输出 XML 格式的函数。

在 SQL Server 时隔 5个根本版本随后,终于在 Microsoft Ignite 2015大会上专业透露,新一代的 SQL Server 2016正式帮忙以往最盛行的数据调换格式— JSON(JavaScript Object Notation)。

 

SQL Server 2016对JSON的协助并不是充实三个JSON数据类型,而是提供三个更轻便的框架,扶助用户在数据Curry处理JSON格式数据。

用户不须要更变现有的表结构,因为SQL Server使用NVA安德拉CHAENVISION数据类型来囤积JSON文件,并且跟现有技术并行匹配,比如全文字笔迹检测索、列存款和储蓄索引、in-memory
OLTP,应用程序不须求做别的修改

 

不要求运用JSON.Net那类工具分析和拍卖JSON数据,利用SQL
Server内置函数就足以处理JSON数据,轻松将查询结构输出为JSON格式,或许搜索JSON文件内容。

 


使用 JSON AUTO 输出JSON 格式

要将select语句的结果以JSON输出,最简单易行的方法是在后头加上 FORAV肆 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

 

我们可以把每列中显得的最大字符数 设置为81九二

图片 2

图片 3

 


加上Root Key

倘使想为FO奥迪Q3 JSON 加上Root Key,能够行使ROOT选项来钦点 Root Key 名称

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

图片 4

 


使用JSON PATH 输出JSON格式

当想要自定义输出JSON格式结构的时候,必须用JSON PATH描述,若SELECT
的字段名称1致,必须用别称形式来重新命名字段名那样才能够继承查询

除此以外,借使字段的默许值为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 201陆 CTP2对于JSON的效劳支撑依旧相比较单薄,例如内置处理JSON格式化的函数,

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

那几个效率要等到CTP3才能6续推出

 

越来越多SQL Server2016好用的效果,敬请期待o(∩_∩)o 

SQL Server201陆 原生支持JSON

 

SQL Server 二〇〇七 开端扶助 XML 数据类型,提供原生的 XML数据类型、XML
索引以及各类管理 XML 或输出 XML 格式的函数。

在 SQL Server 时隔 伍个基本点版本后来,终于在 Microsoft Ignite 20一5大会上规范发布,新一代的 SQL Server 2016正式协理现在最流行的数据交流格式— JSON(JavaScript Object Notation)。

 

SQL Server 201陆对JSON的支撑并不是增多贰个JSON数据类型,而是提供贰个更轻便的框架,援助用户在数据Curry处理JSON格式数据。

用户不需求更变现有的表结构,因为SQL Server使用NVALX570CHA奥迪Q五数据类型来存款和储蓄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

 

咱俩能够把每列中显得的最大字符数 设置为81玖二

图片 2

图片 3

 


加上Root Key

借使想为FOSportage 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 201陆 CTP二对于JSON的功用协理依旧比较简单,例如内置处理JSON格式化的函数,

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

这么些成效要等到CTP3才能陆续推出

 

愈来愈多SQL Server201陆好用的功用,敬请期待o(∩_∩)o 

发表评论

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

网站地图xml地图