当前位置: 首页 > article >正文

MS SQL Table与JSON转换

1.表转换JSON

1.1案例

案例1

 create table #t2
 ([User_id] varchar(20),
 [PWS]   VARCHAR(40)
 )

 INSERT INTO #t2
 SELECT 'ADMIN','12345'
 UNION
  SELECT 'INPUTUSER','YTETS'


  select * from #t2 for json path, without_array_wrapper
  select * from #t2 for json path

运行效果:

{"User_id":"ADMIN","PWS":"12345"},{"User_id":"INPUTUSER","PWS":"YTETS"}

[{"User_id":"ADMIN","PWS":"12345"},{"User_id":"INPUTUSER","PWS":"YTETS"}]

1.2语法解析

若要删除默认括住 FOR JSON 子句的 JSON 输出的方括号,请指定 WITHOUT_ARRAY_WRAPPER 选项。 将此选项用于单行结果,生成单个 JSON 对象作为输出,而不是生成具有单个元素的数组

2.JSON转换表

2.1案例

案例2

create table #t
(id int,
json_date nvarchar(max))

--delete from #t

insert into #t
select 1,'{"User_id":"admin","PSW":"123"}'
insert into #t
select 2,'{"User_id":"INPUTUSER","PSW":"YTETS"}'

 select   * from #t
 cross apply OPENJSON(json_date)
  select  id,
   case when isjson(json_date)=1 then JSON_VALUE(json_date,'$.User_id') end [User_id], 
  case when isjson(json_date)=1 then  JSON_VALUE(json_date,'$.PSW')end PSW
   from #t
  select   * from #t  
 cross apply OPENJSON(json_date)
 WITH (   
              [User_id]   VARCHAR(200)   '$.User_id',  
              PWS     VARCHAR(200)       '$.PWS'
 )

运行效果:

   

  

在上述基础上,增加一下语句:

案例3

insert into #t
select 3,'{"User_id":"ADMIN","PWS":"12345"},{"User_id":"INPUTUSER","PWS":"YTETS"}'
 select   * from #t  
 cross apply OPENJSON(json_date)
  select  id,
		case when isjson(json_date)=1 then JSON_VALUE(json_date,'$.User_id') end [User_id], 
		case when isjson(json_date)=1 then  JSON_VALUE(json_date,'$.PSW')end PSW
   from #t

运行效果:

对于id为3无法达到预期效果。如何解?请参考案例4

案例4

DECLARE @JSON NVARCHAR(MAX)  
SET  @JSON=N'[{"User_id":"ADMIN","PWS":"12345"},{"User_id":"INPUTUSER","PWS":"YTETS"}]'
--SET  @JSON=N'[{"User_id":"INPUTUSER","PSW":"YTETS"}]'
SELECT root.[key] AS RID,TheValues.[key], TheValues.[value]
FROM OPENJSON ( @JSON ) AS root
CROSS APPLY OPENJSON ( root.value) AS TheValues

运行结果:

案例4达到预期,但是JSON一定要带“方括号”

官方案例参考:

案例5

DECLARE @json NVARCHAR(MAX) = N'[  
  {  
    "Order": {  
      "Number":"SO43659",  
      "Date":"2011-05-31T00:00:00"  
    },  
    "AccountNumber":"AW29825",  
    "Item": {  
      "Price":2024.9940,  
      "Quantity":1  
    }  
  },  
  {  
    "Order": {  
      "Number":"SO43661",  
      "Date":"2011-06-01T00:00:00"  
    },  
    "AccountNumber":"AW73565",  
    "Item": {  
      "Price":2024.9940,  
      "Quantity":3  
    }  
  }
]'  
   
SELECT *
FROM OPENJSON ( @json )  
WITH (   
              Number   VARCHAR(200)   '$.Order.Number',  
              Date     DATETIME       '$.Order.Date',  
              Customer VARCHAR(200)   '$.AccountNumber',  
              Quantity INT            '$.Item.Quantity',  
              [Order]  NVARCHAR(MAX)  AS JSON  
 )

2.2语法解析

1:apply有两种形式: cross apply 和 outer apply

CROSS APPLY仅返回外部表中通过表值函数生成结果集的行。OUTER APPLY既返回生成结果集的行,也返回不生成结果集的行,其中表值函数生成的列中的值为 NULL

语法:<left_table_expression>  {cross|outer} apply <right_table_expression>

2.OPENJSON 是一种表值函数,可分析 JSON 文本,并以行和列的形式从 JSON 输入返回对象和属性。 换句话说,OPENJSON 对 JSON 文档提供行集视图。 可以显式指定行集中的列以及用于填充列的 JSON 属性路径。 由于 OPENJSON 返回一组行,因此可以在 Transact-SQL 语句的 FROM 子句中使用 OPENJSON,就如同可以使用任何其他表、视图或表值函数一样

3.错误解决方案

1.案例1错误信息

消息 208,级别 16,状态 1,第 12 行 对象名 'OpenJson' 无效。

OPENJSON 函数仅在兼容级别 130 或更高级别下可用。 如果数据库兼容级别低于 130,SQL Server 将无法找到并运行 OPENJSON 函数。 其他 JSON 函数在所有兼容性级别均可用。

可以在 sys.databases 视图或数据库属性中查看兼容级别。 可以使用以下命令更改数据库的兼容级别:

ALTER DATABASE DatabaseName SET COMPATIBILITY_LEVEL = 130

4.案例4错误信息

消息 13609,级别 16,状态 4,第 6 行
JSON 文本格式不正确。位置 0 中存在非预期的字符 

由于上述测试案例都无方括号,在测试案例4时JSON语句中缺少“方括号,请加上“方括号”


http://www.kler.cn/a/160260.html

相关文章:

  • 【Go】Go Gin框架初识(一)
  • Flink系统知识讲解之:容错与State状态管理
  • 【力扣Hot100】滑动窗口
  • MySQL主从:如何处理“Got Fatal Error 1236”或 MY-013114 错误(percona译文)
  • 最左前缀匹配原则
  • UML系列之Rational Rose笔记一:用例图
  • docker基本管理和相关概念
  • 获取网络ppt资源
  • Terraform实战(一)-Terraform介绍与安装部署
  • C语言——二级指针
  • Day46力扣打卡
  • *p++和(*p)++的区别
  • 异常(C++)
  • 【Spring Boot】如何通过RestTemplate获取另一个服务的接口返回信息
  • 深信服行为管理AC设置禁止用户使用向日葵等远程软件
  • 人工智能-语音识别技术paddlespeech的搭建和使用
  • centos用户相关命令
  • python起步
  • 问卷调查须避免的错误要点(02):避免逻辑错误与提升数据质量
  • 基于jsp+servlet+mybatis的简易在线选课系统
  • Dubbo(二)dubbo调用关系
  • golang使用sip协议 用户名和密码注册到vos3000
  • vue3中如何实现事件总线eventBus
  • 【数据结构(八)】哈希表
  • OpenCV-python numpy和基本作图
  • 甘草书店:#8 2023年11月22日 星期三「“说一套做一套”的甘草与麦田」