SQL Server将查询结果转换为Json格式的解决办法

2022-11-12 09:40:34
内容摘要
这篇文章主要为大家详细介绍了SQL Server将查询结果转换为Json格式的简单示例,具有一定的参考价值,可以用来参考一下。 对此感兴趣的朋友,看看idc笔记做的技术笔记! 脚本源码:
文章正文

这篇文章主要为大家详细介绍了SQL Server将查询结果转换为Json格式的简单示例,具有一定的参考价值,可以用来参考一下。

对此感兴趣的朋友,看看idc笔记做的技术笔记!

脚本源码:

代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
<code>
SET ANSI_NULLS ON
 
GO
 
SET QUOTED_IDENTIFIER ON
 
GO
 
CREATE PROCEDURE[dbo].[SerializeJSON](
 
@ParameterSQL AS VARCHAR(MAX)
 
)
 
AS
 
BEGIN
 
 
 
DECLARE @SQL NVARCHAR(MAX)
 
DECLARE @XMLString VARCHAR(MAX)
 
DECLARE @XML XML
 
DECLARE @Paramlist NVARCHAR(1000)
 
SET @Paramlist = N'@XML XML OUTPUT'
 
SET @SQL = 'WITH PrepareTable (XMLString)'
 
SET @SQL = @SQL + 'AS('
 
SET @SQL = @SQL + @ParameterSQL+ 'FOR XML RAW,TYPE,ELEMENTS'
 
SET @SQL = @SQL + ')'
 
SET @SQL = @SQL + 'SELECT @XML=[XMLString]FROM[PrepareTable]'
 
EXEC sp_executesql @SQL, @Paramlist, @XML=@XML OUTPUT
 
SET @XMLString=CAST(@XML AS VARCHAR(MAX))
 
 
 
DECLARE @JSON VARCHAR(MAX)
 
DECLARE @Row VARCHAR(MAX)
 
DECLARE @RowStart INT
 
DECLARE @RowEnd INT
 
DECLARE @FieldStart INT
 
DECLARE @FieldEnd INT
 
DECLARE @KEY VARCHAR(MAX)
 
DECLARE @Value VARCHAR(MAX)
 
 
 
DECLARE @StartRoot VARCHAR(100);SET @StartRoot='<row>'
 
DECLARE @EndRoot VARCHAR(100);SET @EndRoot='</row>'
 
DECLARE @StartField VARCHAR(100);SET @StartField='<'
 
DECLARE @EndField VARCHAR(100);SET @EndField='>'
 
 
 
SET @RowStart=CharIndex(@StartRoot,@XMLString,0)
 
SET @JSON=''
 
WHILE @RowStart>0
 
BEGIN
 
SET @RowStart=@RowStart+Len(@StartRoot)
 
SET @RowEnd=CharIndex(@EndRoot,@XMLString,@RowStart)
 
SET @Row=SubString(@XMLString,@RowStart,@RowEnd-@RowStart)
 
SET @JSON=@JSON+'{'
 
 
 
-- for each row
 
SET @FieldStart=CharIndex(@StartField,@Row,0)
 
WHILE @FieldStart>0
 
BEGIN
 
-- parse node key
 
SET @FieldStart=@FieldStart+Len(@StartField)
 
SET @FieldEnd=CharIndex(@EndField,@Row,@FieldStart)
 
SET @KEY=SubString(@Row,@FieldStart,@FieldEnd-@FieldStart)
 
SET @JSON=@JSON+'"'+@KEY+'":'
 
-- parse node value
 
SET @FieldStart=@FieldEnd+1
 
SET @FieldEnd=CharIndex('</',@Row,@FieldStart)
 
SET @Value=SubString(@Row,@FieldStart,@FieldEnd-@FieldStart)
 
SET @JSON=@JSON+'"'+@Value+'",'
 
 
 
SET @FieldStart=@FieldStart+Len(@StartField)
 
SET @FieldEnd=CharIndex(@EndField,@Row,@FieldStart)
 
SET @FieldStart=CharIndex(@StartField,@Row,@FieldEnd)
 
END
 
IF LEN(@JSON)>0SET @JSON=SubString(@JSON,0,LEN(@JSON))
 
SET @JSON=@JSON+'},'
 
--/ for each row
 
 
 
SET @RowStart=CharIndex(@StartRoot,@XMLString,@RowEnd)
 
END
 
IF LEN(@JSON)>0SET @JSON=SubString(@JSON,0,LEN(@JSON))
 
SET @JSON='['+@JSON+']'
 
SELECT @JSON
 
 
 
END
 
GO
 
</code>

使用方法:

代码如下:

1
2
3
4
<code>
EXEC[SerializeJSON]'SELECT*FROM[Employee_TBL]'
 
</code>

注:关于SQL Server将查询结果转换为Json格式的简单示例的内容就先介绍到这里,更多相关文章的可以留意

代码注释

作者:喵哥笔记

IDC笔记

学的不仅是技术,更是梦想!