DECLARE @XmlData xml
SET @XmlData= '<?xml version="1.0" encoding="utf-8" ?>
<ROOT PROCESS_DATE="25-Nov-2009" ROW_COUNT="2" VERIFY_TOTAL="654454.54">
<row rowNumber="1">
<Code1>11111</Code1>
<Code2>AAAA </Code2>
</row>
<row rowNumber="2">
<Code1>2222</Code1>
<Code2>BBBB </Code2>
</row>
</ROOT>'
-- Following query returns the Code1, & Code2 for each row.
SELECT
R.i.query('Code1').value('.', 'nvarchar(8)') AS Code1,
R.i.query('Code2').value('.', 'nvarchar(8)') AS Code2
FROM @XmlData.nodes('/ROOT/row') R(i)
-- Now I want to get the rowNumber attribute of each row in the resultset.
SELECT
R.i.query('@rowNumber') AS rowNumber,
R.i.query('Code1').value('.', 'nvarchar(8)') AS Code1,
R.i.query('Code2').value('.', 'nvarchar(8)') AS Code2
FROM @XmlData.nodes('/ROOT/row') R(i)
-- Above query returns error
Q
如何读取XML
1
A
回答
0
我没有SQL服务器方便的属性,但我的直觉告诉我尝试:
R.i.query('.').value('@rowNumber', 'int') AS rowNumber
0
您可以用data()
解决方法查询属性:
R.i.query('data(row/@Name)').value('.','int') AS rowNumber
2
DECLARE @x XML ;
SET @x = '<?xml version="1.0" encoding="utf-8" ?>
<ROOT PROCESS_DATE="25-Nov-2009" ROW_COUNT="2" VERIFY_TOTAL="654454.54">
<row rowNumber="1">
<Code1>11111</Code1>
<Code2>AAAA </Code2>
</row>
<row rowNumber="2">
<Code1>2222</Code1>
<Code2>BBBB </Code2>
</row>
</ROOT>' ;
SELECT v.value('.', 'VARCHAR(20)') AS Name
FROM @x.nodes('(/ROOT/row/@*)') x (v)
相关问题
- 1. 如何读取XML
- 2. Qt如何读取XML?
- 3. 如何读取XML用JDOM
- 4. 如何读取XML数据
- 5. 如何从XML读取值?
- 6. 如何读取XML文件
- 7. 如何使用xml读取器读取XML文件?
- 8. 如何读取和获取xml的值
- 9. 读取XML injava
- 10. 读取XML值
- 11. 读取的XML
- 12. 读取XML与
- 13. 读取XML
- 14. 如何读取本地xml文件
- 15. 如何读取/写入xml文件?
- 16. 在SQL Server中如何读取XML值
- 17. C#如何读取XML用的XElement
- 18. 如何通过元素ID读取XML?
- 19. 如何读取使用LINQ到XML
- 20. 如何在xml中读取Dc:creator标签?
- 21. 如何从XML文件读取数组?
- 22. PHP - 如何读取私人XML文件?
- 23. 如何在C#中读取XML文档
- 24. 如何从.xml文件读取信息
- 25. 如何在C#中读取xml文件?
- 26. 如何读取XML标记的内容
- 27. 如何使用Linq读取XML
- 28. 如何在XNA中读取.XML文件?
- 29. 如何使用EMF读取XML文件?
- 30. 如何从jar中读取xml文件