sql - 在 SQL Server 2017 中粉碎 XML
问题描述
给定以下 SQL:
drop table if exists #testXML
create table #testXML (InputXML xml)
insert into #testXML
values ('<?xml version="1.0" encoding="UTF-8" standalone="yes" ?>
<document>
<table name="tableName1">
<column name="ID">000010313500011171011710001 </column>
<column name="StartDate">10/27/2019</column>
<column name="EndDate">11/02/2019</column>
</table>
</document>')
我试图得到这样的输出:
ID StartDate EndDate
000010313500011171011710001 10/27/2019 11/02/2019
这是我的开始,但我只是在这一点上挣扎。
SELECT
px1.tbl.value('@name','nvarchar(50)') as TableName
,px2.col.value('@name','nvarchar(50)') as ColName
from #testXML px
cross apply inputxml.nodes ('/document/table') as px1(tbl)
cross apply inputxml.nodes ('/document/table/column') as px2(col)
这是在 SQL Server 2017 上。
解决方案
@name
您的 SQL 需要通过利用属性值进行如下调整。
SQL
-- DDL and sample data population, start
DECLARE @tbl TABLE (InputXML xml)
INSERT INTO @tbl (InputXML)
VALUES ('<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<document>
<table name="tableName1">
<column name="ID">000010313500011171011710001</column>
<column name="StartDate">10/27/2019</column>
<column name="EndDate">11/02/2019</column>
</table>
</document>');
-- DDL and sample data population, end
SELECT col.value('(column[@name="ID"]/text())[1]','nvarchar(50)') as ID
, col.value('(column[@name="StartDate"]/text())[1]','DATE') as StartDate
, col.value('(column[@name="EndDate"]/text())[1]','DATE') as EndDate
FROM @tbl tbl
CROSS APPLY tbl.InputXML.nodes('/document/table') AS tab(col);
输出
+-----------------------------+------------+------------+
| ID | StartDate | EndDate |
+-----------------------------+------------+------------+
| 000010313500011171011710001 | 2019-10-27 | 2019-11-02 |
+-----------------------------+------------+------------+
推荐阅读
- amazon-ec2 - 需要为 API 调用设置 ejabberd
- ubuntu - 我如何知道 ubuntu 14.04 LTS 上的 LLVM 版本
- android - 到 Firestore 数据库中的 Firebase UID 或令牌?
- c# - C# .net Core 和 Oracle 集编码
- php - 检查令牌是否在 Laravel 中过期
- javascript - 类型错误:db.close 不是函数
- android - 从 worldcam travel API 预览直播视频
- node.js - 尝试通过云功能将文件从存储上传到 FTP 服务器时超时
- javascript - ( Opencart v2.3 ) 在 iphone 中清空 (minicart) 中的所有购物车项目
- mysql - 在 MySQL 中使用多个 JOIN 表声明一个变量