暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

SQL Server 2016新特性:对JSON的支持

原创 沙沃兴 2023-02-18
1402

        随着JSON的流行,SQL Server 2016开始支持JSON数据类型,不仅可以直接输出JSON格式的结果集,还能读取JSON格式的数据。对于有用到JSON格式的应用程序来说,这无疑是一利器,因为不再需要使用JSON.NET这类工具进行分析和处理JSON数据,直接利用SQL Server内置函数就可以处理,轻松将查询结果输出为JSON格式,或者搜索JSON文件内容。

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

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


一、使用JSON AUTO输出JSON格式

1、将查询直接输出JSON格式

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

SELECT * FROM tu_TuCommentManage

SELECT * FROM tu_TuCommentManage FOR JSON AUTO

0


2、加上Root Key

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

SELECT * FROM tu_TuCommentManage FOR JSON AUTO,ROOT('RootKey')

0


使用JSON PATH输出JSON格式

当需要,定义输出JSON格式结构的时候,必须用JSON PATH描述,若SELECT的字段名称相同,必须用别名方式来重新命名字段名这样才可以继续查询。另外,如果字段的默认值为NULL,那么输出JSON时,JSON会忽略NULL的值。如果要显示NULL值,可以加上INCLUDE_NULL_VALUES选项(同样适用于JSON_AUTO字句)

1、JSON PATH直接输出

SELECT * FROM tu_TuCommentManage WHERE id = 1 FOR JSON PATH

0


2、JSON PATH + ROOT KEY输出

SELECT * FROM tu_TuCommentManage WHERE id = 1 FOR JSON PATH,ROOT('RootKey')

0


3、为NULL的数据输出JSON格式。

SELECT * FROM tu_TuCommentManage WHERE id = 1 FOR JSON PATH,ROOT('RootKey'),INCLUDE_NULL_VALUES

0



二、解析JSON格式的数据

使用OPENJSON函数:

DECLARE @json1 NVARCHAR(MAX) ,

@json2 NVARCHAR(MAX);

SET @json1 = N'{"name": "John", "surname":"Doe"}';

SELECT *

FROM OPENJSON(@json1);

0








https://blog.csdn.net/weixin_39934264/article/details/80450591

https://www.cnblogs.com/lyhabc/p/4747694.html




























「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论