nvarchar转换为numeric时出错_SQL--每日一解------FOR JSON子句将SQL结果的格式为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格式。

1. 标准的SELECT 格式输出

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

af0d92581a699d4fb66470cb186e29d9.png

2. FOR JSON AUTO:SELECT语句的结果以JSON输出。

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

f7e54ce49807245c067746c42de4a1d5.png

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

用ROOT选项来自定义ROOT 节点的名称:

05f00835a79d50a5e81b17cd8a75d999.png

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

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

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

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

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

7aa6a97103185c7620cae6a3d26e8df0.png

6. 添加其他自定义字段

在使用的过程中往往还要添加其他自定义字段,如总行数(利用此方法还可以拼接两个结果集)

b1632077eca855d924f2f6baa41da95a.png
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值