从XML导入

KDS
DECLARE @index int 
DECLARE @XMLdoc varchar(8000)
SET @XMLdoc ='<Sales>
<Company>101</Company>
<Warehouse>S001</Warehouse>
<InvoiceNumber>1001</InvoiceNumber>
<Amount>1000.0000</Amount>
<CreateDate>20180527</CreateDate>
<Company>101</Company>
<Warehouse>S002</Warehouse>
<InvoiceNumber>1002</InvoiceNumber>
<Amount>2000.0000</Amount>
<CreateDate>20180527</CreateDate>
</Sales>'
EXEC sp_xml_preparedocument @index OUTPUT, @XMLdoc
SELECT * FROM OPENXML (@index, 'Sales',2)
WITH (Company int,Warehouse nvarchar(20),InvoiceNumber nvarchar(40),Amount 
nvarchar(10),CreateDate nvarchar(20))
EXEC sp_xml_removedocument @index

即使XML格式的数据包含两行数据,上面的查询也只返回单行。我希望这两行都是该查询的结果。

Shnugo

首先:FROM OPENXML与准备和删除文档的相应SP一起已过时,不应再使用。而是使用本机XML类型的方法。

假设两行意味着两个<Sales>块,我想建议一下:

DECLARE @XMLdoc XML=
N'<Sales>
  <Company>101</Company>
  <Warehouse>S001</Warehouse>
  <InvoiceNumber>1001</InvoiceNumber>
  <Amount>1000.0000</Amount>
  <CreateDate>20180527</CreateDate>
  <Company>101</Company>
  <Warehouse>S002</Warehouse>
  <InvoiceNumber>1002</InvoiceNumber>
  <Amount>2000.0000</Amount>
  <CreateDate>20180527</CreateDate>
</Sales>
<Sales>
  <Company>999</Company>
  <Warehouse>999</Warehouse>
  <InvoiceNumber>999</InvoiceNumber>
  <Amount>1000.0000</Amount>
  <CreateDate>20180527</CreateDate>
  <Company>101</Company>
  <Warehouse>S002</Warehouse>
  <InvoiceNumber>1002</InvoiceNumber>
  <Amount>2000.0000</Amount>
  <CreateDate>20180527</CreateDate>
</Sales>';

SELECT s.value(N'(Company/text())[1]',N'int') AS Company
      ,s.value(N'(Warehouse/text())[1]',N'nvarchar(max)') AS Warehouse
      ,s.value(N'(InvoiceNumber/text())[1]',N'int') AS InvoiceNumber
      ,s.value(N'(Amount/text())[1]',N'decimal(14,6)') AS Amount
      --and so on
FROM @XMLdoc.nodes(N'/Sales') AS A(s) 

更新(请避免跟进问题!)

您询问属性的评论指向如下内容:

SELECT 101 AS [@Company]
      ,Warehouse
      --more elements
FROM SomeWhere
FOR XML PATH('Idocs'),ROOT('Sales');

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章

TOP 榜单

  1. 1

    来自Microsoft Office加载项taskpane.js的MySQL驱动程序模块的空引用

  2. 2

    使用AWS Cognito和React的仅限Facebook / Google的登录名(无用户名/密码)

  3. 3

    创建Windows Phone 8应用并将其连接到数据库的最佳方法(最好是SQL Server)

  4. 4

    为什么Java中的System.out.println()打印到控制台?

  5. 5

    卷曲函数无法解析来自bash中变量的代理

  6. 6

    是什么在Android的consumer-rules.pro和proguard-rules.pro之间的区别?

  7. 7

    设置与Apache POI Excel表散点图标记图标的颜色

  8. 8

    将Qt Pyside2与asyncio await语法一起使用?

  9. 9

    崇高的文字+蟒蛇的蟒蛇

  10. 10

    任务':app:minifyReleaseWithR8'.java.lang.NullPointerException的执行失败(无错误消息)

  11. 11

    OpenJDK的和AdoptOpenJDK的区别

  12. 12

    大型数据集缓存到Spark内存中时,“超出了GC开销限制”(通过sparklyr和RStudio)

  13. 13

    “执行测试CMAKE_HAVE_LIBC_PTHREAD”失败实际上是什么意思?

  14. 14

    使用Core 2.2中的Identity,如何在关闭浏览器15分钟后保持会话活动?

  15. 15

    React中的ForwardRefExoticComponent和ForwardRefRenderFunction有什么区别?

  16. 16

    猫鼬查找结果,然后将字段替换为findOne

  17. 17

    如何降级Google Colab的Torch版本

  18. 18

    Keras提前停止回调错误,val_loss指标不可用

  19. 19

    如何避免VSCode中的“导入路径不能以.ts扩展名结尾”错误?

  20. 20

    Nuxt.JS:如何在页面中获取路由URL参数

  21. 21

    是否有为什么会AccessibilityManager.sInstance导致内存泄漏的一个原因?

热门标签

归档