在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
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加上根节点 3、FOR JSON PATH输出:可通过列别名来定义JSON对象的层次结构
这个特性非常类似于早期SQL Server版本中的For Xml Path子句,可以使用斜线来定义xml的层次结构。 4、FOR JSON PATH+ROOT输出:为JOSN加上根节点 5、INCLUDE_NULL_VALUES:值null的字段需要显示出现。 6、列的别名,可以增加带有层级关系的节点。 二、 解析JSON格式的数据 1、使用OPENJSON()函数: 2、通过WITH选项,自定义输出列: 三、JSON函数 declare @param nvarchar(max); set @param = N'{ "info":{ "type":1, "address":{ "town":"Bristol", "county":"Avon", "country":"England" }, "tags":["Sport", "Water polo"] }, "type":"Basic" }'; 1、ISJSON:测试字符串是否包含有效 JSON。
返回:OK 2、JSON_VALUE :从 JSON 字符串中提取标量值。
返回:Bristol,Water polo 3、JSON_QUERY :从 JSON 字符串中提取对象或数组。
{ "type":1, "address":{ "town":"Bristol", "county":"Avon", "country":"England" }, "tags":["Sport", "Water polo"] } 4、JSON_MODIFY :更新 JSON 字符串中属性的值,并返回已更新的 JSON 字符串。
返回: { "info":{ "type":1, "address":{ "town":"London", "county":"Avon", "country":"England" }, "tags":["Sport", "Water polo"] }, "type":"Basic" } 四、注意事项 SQL2016 中的新增的内置JSON进行了简单介绍,主要有如下要点:
好了这篇文章就介绍到这了,需要的朋友可以参考一下。 |
请发表评论