当前位置 主页 > 网站技术 > 代码类 >

    SQL Server之JSON 函数详解

    栏目:代码类 时间:2019-11-12 06:11

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

    1 概述

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

    2 具体内容

    2.1 JSON 函数

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

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

    2.2 ISJSON

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

    2.2.1 例子

    2.3 JSON_VALUE

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

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

    2.4 JSON_QUERY

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

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

    2.5 JSON_MODIFY

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

    小结

    3 参考文献

    【01】https://docs.microsoft.com/zh-cn/sql/t-sql/language-elements/expressions-transact-sql

    4 版权

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

    以下是一些补充

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

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

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

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