sqlserver常见函数(SQL Server之JSON 函数详解)
sqlserver常见函数
SQL Server之JSON 函数详解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的成员层次结构将会与别名中的层次结构保持一致。
这个特性非常类似于早期SQL Server版本中的For Xml Path子句,可以使用斜线来定义xml的层次结构。
4、FOR JSON PATH+ROOT输出:为JOSN加上根节点
5、INCLUDE_NULL_VALUES:值null的字段需要显示出现。
为NULL的数据在输出JSON时,会被忽略,若想要让NULL的字段也显示出来,可以加上选项INCLUDE_NULL_VALUES,该选项也适用于AUTO。
6、列的别名,可以增加带有层级关系的节点。
比如下面的SQL,增加了一个“SN”节点,把栏位SERNUM和CLIMAT放在里面:
二、 解析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。
print iif(isjson(@param) > 0, 'OK', 'NO');
返回:OK
2、JSON_VALUE :从 JSON 字符串中提取标量值。
print json_value(@param, '$.info.address.town');
print json_value(@param, '$.info.tags[1]');
返回:Bristol,Water polo
3、JSON_QUERY :从 JSON 字符串中提取对象或数组。
print json_query(@param, '$.info');
{ "type":1, "address":{ "town":"Bristol", "county":"Avon", "country":"England" }, "tags":["Sport", "Water polo"] }
4、JSON_MODIFY :更新 JSON 字符串中属性的值,并返回已更新的 JSON 字符串。
print json_modify(@param, '$.info.address.town', 'London');
返回:
{ "info":{ "type":1, "address":{ "town":"London", "county":"Avon", "country":"England" }, "tags":["Sport", "Water polo"] }, "type":"Basic" }
四、注意事项
SQL2016 中的新增的内置JSON进行了简单介绍,主要有如下要点:
- JSON能在SQLServer2016中高效的使用,但是JSON并不是原生数据类型;
- 如果使用JSON格式必须为输出结果是表达式的提供别名;
- JSON_VALUE 和 JSON_QUERY 函数转移和获取Varchar格式的数据,因此必须将数据转译成你需要的类型。
- 在计算列的帮助下查询JSON可以使用索引进行优化。
好了这篇文章就介绍到这了,需要的朋友可以参考一下。
- sql 基本函数(SQL开窗函数的具体实现详解)
- apache2.4支持php5.5吗(WINDOWS下php5.2.4+mysql6.0+apache2.2.4+ZendOptimizer-3.3.0配置)
- sql执行原理详解(Sql server中内部函数fn_PhysLocFormatter存在解析错误详解)
- mysql意外查不到数据(MySQL 丢失数据的原因及解决)
- SQL Server 各个版本支持的功能
- mysql数据表怎么复制(MySQL 复制表的方法)
- 最新版MySQL 8.0.22下载安装超详细教程(Windows 64位)(最新版MySQL 8.0.22下载安装超详细教程Windows 64位)
- python中怎么连接mysql(python远程连接MySQL数据库)
- SQLServer中JSON文档型数据的查询问题解决(SQLServer中JSON文档型数据的查询问题解决)
- mysql 性能调优技巧(4 款 MySQL 调优工具,公司大神都在用!)
- mysqldecimal类型转换(mysql中decimal数据类型小数位填充问题详解)
- mysql常用四种日志(MySQL 撤销日志与重做日志Undo Log与Redo Log相关总结)
- mysql 查询语法常见问题(MySQL 异常有这一篇就够了!)
- mysql分组函数入门(详解MySQL 数据分组)
- 阿里云mysql配置升级注意事项(详解如何在阿里云上安装mysql)
- 搭建php和mysql的运行环境(Windows环境开发PHP完整配置教程Apache+Mysql+PHP)
- 智能手表兼容Windows和Android 无需充电挑战苹果(智能手表兼容Windows和Android)
- 一天一冲也算表 麦步,一款待机 21 天的智能手表体验评测(一天一冲也算表)
- 魅族智能手表充电座曝光 Type-C 接口,线座分离设计(魅族智能手表充电座曝光)
- 华为 Watch GT2 Pro 智能手表曝光,新增支持无线充电(华为WatchGT2)
- vivo首款智能手表来了 也有血氧饱和度监测,一次充电18天续航(vivo首款智能手表来了)
- 你知道 七夕 的真正含义吗(你知道七夕的真正含义吗)
热门推荐
- sqlserver表导入数据(在SQLserver数据库之间进行传表和传数据的图文教程)
- 如何彻底关闭vmwareworkstation(关于vmware workstations与device/credential不兼容启动报错的问题)
- SQL Server作业活动监视器
- Web开发中的几个建议
- dedecms时间代码(Dedecms中常用数据调用的sql语句汇总)
- HTTP header中Cache-control的介绍
- mysqldump备份缺点(MySQL5.7 mysqldump备份与恢复的实现)
- php导出excel使用方法(PHP使用ajax的post方式下载excel文件简单示例)
- dedecms水印(dedecms上传透明背景图片变成黑色的解决办法)
- 怎么用腾讯云主机搭建网站(用云主机怎么搭建网站?云主机建网站完整流程)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9