- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
我刚刚开始通过 SQL Server Management Studio 将 XML 文件读入表中。可能有更好的方法,但我想使用这种方法。
目前,我正在阅读有关人员记录的标准 XML 文件。 <record>
tag是每一行数据的最高级别。我想将所有记录读入我的 SQL 表中的不同行。
到目前为止,我使用以下方法进展顺利:
SELECT
-- Record
category, editor, entered, subcategory, uid, updated,
-- Person
first_name, last_name, ssn, ei, title, POSITION,
FROM OPENXML(@hDoc, 'records/record/person/names')
WITH
(
-- Record
category [varchar](100) '../../@category',
editor [varchar](100) '../../@editor',
entered Datetime '../../@entered',
subcategory [varchar](100) '../../@subcategory',
uid BIGINT '../../@uid',
updated [varchar](100) '../../@updated',
-- Person
first_name [varchar](100) 'first_name',
last_name [varchar](100) 'last_name',
ssn [varchar](100) '../@ssn',
ei [varchar](100) '../@e-i',
title [varchar](100) '../title',
Position [varchar](100) '../position',
)
但是这种方法效果很好,因为标签名称对于每个记录/人都是唯一的。我遇到的问题在 <Person>
范围内标签我现在有一个 <Aliases>
包含超过 1 个列表的标记 <Alias> test name </Alias>
标签。如果我使用上述方法并引用 '../aliases',我会将所有 Alias 元素作为一个长字符串行混合在一起。如果我只是尝试 '../aliases/alias',则每个记录行只返回第一个元素。例如,如果 Aliases 标记集中有 10 个 Alias 元素,我希望返回 10 行。
有没有一种方法可以指定当更高级别的标签中有多个同名标签时,将它们全部返回而不是仅返回一行?
以下是我所指的 XML 中的示例 block :
- <aliases>
<alias>test 1</alias>
<alias>test 2</alias>
<alias>test 3</alias>
</aliases>
我想要 SQL 表中的以下内容:
Record Aliases
Record 1 test 1
Record 1 test 2
Record 1 test 3
Record 2 test 4
Record 2 test 5
但我得到的只是:
Record 1 test 1
Record 2 test 4
如果我没有正确解释这一点,我们深表歉意 - 将不胜感激任何帮助。
最佳答案
正如 Antonio 所指出的,我会使用 XQuery 而不是 Openxml。我已经猜到了您的源 xml,并为您的 2 个查询提供了代码:
/* Please note I have used different cases than you to follow a standard (first letter capitialised for elements, lowercase for attributes.
As xml is case sensitive, you may need to change the below code to suit the case of your data */
/* Bring your xml into an xml variable */
DECLARE @xml xml = '
<Records>
<Record category="category1" editor="editor1" entered="2015-01-01" subcategory="subcategory1" uid="100001" updated="updated1">
<Person ssn="ssn1" e-i="ei1">
<Title>Title1</Title>
<Position>Position1</Position>
<Names>
<First_name>FirstName1</First_name>
<Last_name>LastName1</Last_name>
<Aliases>
<Alias>test1</Alias>
<Alias>test2</Alias>
<Alias>test3</Alias>
</Aliases>
</Names>
</Person>
</Record>
<Record category="category2" editor="editor2" entered="2015-01-02" subcategory="subcategory2" uid="100002" updated="updated2">
<Person ssn="ssn2" e-i="ei2">
<Title>Title2</Title>
<Position>Position2</Position>
<Names>
<First_name>FirstName2</First_name>
<Last_name>LastName2</Last_name>
<Aliases>
<Alias>test4</Alias>
<Alias>test5</Alias>
</Aliases>
</Names>
</Person>
</Record>
</Records>'
/* The unary relationship of 1 element/attribute type per record in xpath */
SELECT T.rows.value('@category[1]', '[varchar](100)') AS Category
,T.rows.value('@editor[1]', '[varchar](100)') AS Editor
,T.rows.value('@entered[1]', '[Datetime]') AS Entered
,T.rows.value('@subcategory[1]', '[varchar](100)') AS Subcategory
,T.rows.value('@uid[1]', '[bigint]') AS [UID]
,T.rows.value('@updated[1]', '[varchar](100)') AS Updated
,T.rows.value('(Person/Names/First_name)[1]', '[varchar](100)') AS First_Name
,T.rows.value('(Person/Names/Last_name)[1]', '[varchar](100)') AS Last_Name
,T.rows.value('(Person/@ssn)[1]', '[varchar](100)') AS SSN
,T.rows.value('(Person/@e-i)[1]', '[varchar](100)') AS ei
,T.rows.value('(Person/Title)[1]', '[varchar](100)') AS Title
,T.rows.value('(Person/Position)[1]', '[varchar](100)') AS Position
FROM @xml.nodes('/Records/Record') T(rows)
/* Record to alias, one-to-many mapping */
SELECT T.rows.value('../../../../@category[1]', '[varchar](100)') AS Category
,T.rows.value('.', '[varchar](100)') AS Alias
FROM @xml.nodes('/Records/Record/Person/Names/Aliases/Alias') T(rows)
关于SQL OpenXML 多标签问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22530621/
我的 C# 应用程序使用 OpenXML 创建一个 MSWord 文档,其中已经包含多个表。最后一部分是添加条形图。我找不到这个案例的好例子。 谢谢你的帮助! 我正在从头开始创建文档。从...开始:
我正在使用一个模板文档,该文档使用 CustomXmlBlocks 作为占位符来放置表格和其他信息。我需要能够以某种方式将图像放入其中一个 block 中......即使它首先放入运行中。 图像以字节
我正在以编程方式将 OpenXML 段落添加到 Word 文档中,并且稍后我需要能够将该段落识别为我的段落。关于如何做到这一点有什么想法吗?我尝试插入 XML 注释和扩展属性,但是当您将文档保存在 w
我想使用 openxml 删除一列,我能够清除单元格的内容,但一直无法找到删除列的文档,以便在删除列时向左移动其他单元格。如何使用 openxml 删除列,它将单元格向左移动? 最佳答案 我发现 Op
我找不到任何可以告诉我 txBody 标签中的文本是否带有项目符号的指标,您能否请我确定我应该使用哪个指标来了解文本是项目符号还是普通文本? -谢谢 最佳答案 在 txBody 标签内,您可以查找标签
我目前正在尝试使用 PHPWord 库及其模板系统来处理 docx 文件。我已经找到并更新了这个库的某人(不记得名字,但它并不重要)的路径,该库可以使用表(复制其行,然后在每一行上使用 PHPWord
这个问题已经有答案了: 已关闭11 年前。 Possible Duplicate: Open Xml and Date format in Excel cell 我正在尝试从 DataGridView
我发现各种元素非常困惑。几乎每个元素似乎都有一个与之关联的“部分”,我不确定它们是如何粘合在一起的。 工作簿工作簿部分工作表工作表部分 我也对 DocumentFormat.OpenXml.Packa
我有一个存储在 Bitmap 对象中的图像,我想将其粘贴到 OpenXML 文档中。我尝试使用 MemoryStream 作为中间步骤,如下所示: ImagePart part = container
我试图理解 OpenXML 电子表格的内部文件内容。在一些文件中,我发现了这个字符串。其他标签具有相同的前缀。标签也可以有前缀 p: w: 等。 你能帮我理解这些前缀在标签中的含义吗? 最佳答案 您可
我的预期结果是: 你好 世界! 但是当我使用以下代码时: MainDocumentPart mainDocumentPart = package.AddMainDo
我需要将多个 .docx 文件收集到一个文件夹中,并将它们“链接”成一个将显示给用户的文档。 现在我已经阅读了 Brian Jones' article虽然听起来很有希望,但我遇到了一个问题。 当我使
我正在使用 OpenXml 生成 Excel 文件,在研究了大量不同的示例代码和 SDK Productivity Tool 后,终于得到了我想要的东西。只有一件事我无法回避。当我使用 Excel 打
我正在使用 openxml 创建 WordProcessingDocuments(工作正常,生成的 word 文档正是我想要的),现在我正在尝试使用 openxml Powertools 将这些新创建
我使用 OpenXML SDK 2.5 编写了一个 Word 文档,当我在 MS Office 中预览该文档时,该文档给出了预期的外观和格式。 现在我需要将此文档转换为 HTML 文档,我开始了解 O
我是 .net 编码员,我对 ColdFusion 真的很陌生。我编写了一个自动生成发票的 .dll 库。我需要使用 ColdFusion 应用程序中的库。我已经成功地将我的库中的类加载为 coldf
以前我发布了一个问题,如何将数据集中的数据填充到 excel 工作表中,而不是如何使用该数据创建图表。那篇文章不太走运,但现在我设法从数据集中填充数据,但也在努力根据该数据创建图表,我希望图表与我的数
快要被这个问题搞疯了。我确信它是如此简单,我只是错过了它,但我一生都无法找出如何使用 C# 中的 OpenXml SDK v2.0 更改 Word 2007 中的内容控件的内容。 我创建了一个带有纯文
我正在编写一个小应用程序,它将路径作为输入,然后获取该路径中的每个 docx 文件,用关键字替换每个超链接。 奇怪的是,我发现了两种超链接,第一种来自 WordprocessingDocument E
我有一段文字想在文档的中央出现。如何在docx4j中执行此操作?我目前正在使用: PPr paragraphProperties = factory.createPPr(); //cr
我是一名优秀的程序员,十分优秀!