我得到了一个.xml文件,我需要将其作为DataSet读入我的代码(作为后台,该文件是通过在C#中创建DataSet并调用dataSet.WriteXml(文件,XmlWriteMode.IgnoreSchema)创建的,但这是通过其他人).
.xml文件的形状如下:
<?xml version="1.0" standalone="yes"?> <NewDataSet> <Foo> <Bar>abcd</Bar> <Foo>efg</Foo> </Foo> <Foo> <Bar>hijk</Bar> <Foo>lmn</Foo> </Foo> </NewDataSet>
DataSet ds = new DataSet(); ds.readxml(file);
使用断点,在此行之后ds.Tables [0]看起来像这样(使用破折号代替下划线,我无法正确格式化):
Bar Foo-Id Foo-Id-0 abcd 0 null null 1 0 hijk 2 null null 3 2
我找到了一个解决方法(我知道有很多)并且能够成功读取.xml,但我想了解为什么ds.readxml(文件)以这种方式执行,所以我将能够避免未来的问题.谢谢.
对于嵌套的Foo标记,这似乎是正确的:
<NewDataSet> <Foo> <!-- Foo-Id: 0 --> <Bar>abcd</Bar> <Foo>efg</Foo> <!-- Foo-Id: 1,Parent-Id: 0 --> </Foo> <Foo> <!-- Foo-Id: 2 --> <Bar>hijk</Bar> <Foo>lmn</Foo> <!-- Foo-Id: 3,Parent-Id: 2 --> </Foo> </NewDataSet>
所以这正确地成为你的结果中的4条记录,父子键为“Foo-Id-0”
尝试:
<NewDataSet> <Rec> <!-- Rec-Id: 0 --> <Bar>abcd</Bar> <Foo>efg</Foo> </Rec> <Rec> <!-- Rec-Id: 1 --> <Bar>hijk</Bar> <Foo>lmn</Foo> </Rec> </NewDataSet>
哪个应该导致:
Bar Foo Rec-Id abcd efg 0 hijk lmn 1