SqlServer将查询结果转换为XML和JSON

 更新时间:2017年07月06日 15:47:02   作者:ArtlessBruin  
这篇文章主要介绍了SqlServer将查询结果转换为XML和JSON的相关资料,需要的朋友可以参考下

很久之前用到的,现在整理在这,里面一些代码来源于网上,不过有些bug已被我修改了。

1.查询结果转XML

DECLARE @ParameterSQL NVARCHAR(MAX)='SELECT * FROM table';
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))
SELECT @XML;
SELECT @XMLString;

其中@ParameterSQL为要查询的语句,@XMLXML格式数据,@XMLStringXML转成字符串

2.查询结果转JSON

查询结果转换成json需要经过两个步骤,首先将查询结果转成XML数据,然后通过XML数据转成json

XML转JSON的存储过程如下:

CREATE PROCEDURE [dbo].[SerializeJSON] (
   @XML XML,
   @json_xml NVARCHAR(MAX) OUTPUT
  )
AS
BEGIN
  DECLARE @XMLString NVARCHAR(MAX);
  SET @XMLString = CAST(@XML AS NVARCHAR(MAX));
  BEGIN TRY--//开始捕捉异常
    DECLARE @JSON NVARCHAR(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);
        DECLARE @end INT = CHARINDEX('/>', @Row, @FieldStart);
        IF @end<1
          OR @end>@FieldEnd
        BEGIN
          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 + '",';
        END;
        SET @FieldStart = @FieldStart + LEN(@StartField);
        SET @FieldEnd = CHARINDEX(@EndField, @Row, @FieldStart);
        SET @FieldStart = CHARINDEX(@StartField, @Row, @FieldEnd);
      END;
      IF LEN(@JSON)>0
        SET @JSON = SUBSTRING(@JSON, 0, LEN(@JSON));
      SET @JSON = @JSON + '},';
      --// for each row
      SET @RowStart = CHARINDEX(@StartRoot, @XMLString, @RowEnd);
    END;
    IF LEN(@JSON)>0
      SET @JSON = SUBSTRING(@JSON, 0, LEN(@JSON));
    --//SET @JSON = '[' + @JSON + ']';
    SET @json_xml = @JSON;
  END TRY--//结束捕捉异常
  BEGIN CATCH--//有异常被捕获
    SET @json_xml = @XMLString;
  END CATCH;--//结束异常处理
END;

以上所述是小编给大家介绍的SqlServer将查询结果转换为XML和JSON,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

相关文章

  • sql中COALESCE函数的使用小结

    sql中COALESCE函数的使用小结

    COALESCE函数用于从其参数列表中返回第一个非NULL值,本文主要介绍了sql中COALESCE函数的使用小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2024-04-04
  • 在IDEA上面连接Sql Server数据库教程(亲测有用)

    在IDEA上面连接Sql Server数据库教程(亲测有用)

    这篇文章主要给大家介绍了关于在IDEA上面连接Sql Server数据库的相关资料,Idea的还有个强大之处就是连接数据库,就可以少开一个数据库工具,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2023-11-11
  • SQL 复合查询条件(AND,OR,NOT)对NULL值的处理方法

    SQL 复合查询条件(AND,OR,NOT)对NULL值的处理方法

    在SQL的3值逻辑下,一个查询条件可以产生以下三种情况:TRUE,FALSE,NULL。只有那些满足WHERE子句的值是TRUE的记录才出现在结果表中。
    2011-04-04
  • SqlServer异常处理常用步骤

    SqlServer异常处理常用步骤

    SQL Server常见的问题主要是SQL问题造成,常见的主要是CPU过高和阻塞。关于SqlServer异常处理常用步骤有哪些呢?大家了解吗?下面小编通过本篇文章给大家介绍SqlServer异常处理常用步骤,感兴趣的朋友一起看看吧
    2015-11-11
  • 浅谈Transact-SQL

    浅谈Transact-SQL

    Transact-SQL 是使用 SQL Server 的核心。 与 SQL Server 实例通信的所有应用程序都通过将 Transact-SQL 语句发送到服务器进行通信,而不管应用程序的用户界面如何。
    2014-08-08
  • 数据库中布尔值(true和false)的存储方式示例详解

    数据库中布尔值(true和false)的存储方式示例详解

    这篇文章主要介绍了多种数据库中布尔值的存储类型,包括TINYINT、BOOLEAN/BOOL、BIT和CHAR/VARCHAR,并讨论了每种类型的特点、适用场景以及选择布尔值存储类型时需要考虑的因素,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2025-03-03
  • ASP.NET和MSSQL高性能分页实例代码

    ASP.NET和MSSQL高性能分页实例代码

    这篇文章主要介绍了ASP.NET和MSSQL高性能分页实例代码的相关资料,需要的朋友可以参考下
    2016-01-01
  • SQL Server时间转换3种方法总结

    SQL Server时间转换3种方法总结

    SQL Server中处理日期和时间的常用方法有三种:FORMAT、CONVERT和DATEADD,这篇文章主要介绍了SQL Server时间转换的3种方法,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2024-09-09
  • SQL窗口函数之取值窗口函数的使用

    SQL窗口函数之取值窗口函数的使用

    取值窗口函数可以用于返回窗口内指定位置的数据行,本文就主要介绍了SQL 取值窗口函数的具体使用,具有一定的参考价值,感兴趣的可以了解一下
    2022-04-04
  • 一文搞懂MySQL脏读,幻读和不可重复读

    一文搞懂MySQL脏读,幻读和不可重复读

    这篇文章主要介绍了一文搞懂MySQL脏读,幻读和不可重复读,MySQL 默认的事务隔离级别是可重复读,文章通过MySQL 中事务的隔离级别展开全文详细内容,需要的小伙伴可以参考一下
    2022-05-05

最新评论