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。