从XML创建具有1个表和0行的DataSet

时间:2013-04-23 15:44:13

标签: c# xml dataset

我目前正在使用此

从XML流创建DataSet
DataSet dataSet = new DataSet();
dataSet.ReadXml(xml);

我试过了,

<?xml version="1.0" standalone="yes"?>
<NewDataSet>
  <Table>
  </Table>
</NewDataSet>

其中创建DataSet,其中Tables[0]是一个名为“NewDataSet”的表,其中1列称为“表”,1行表示“表”的值为“”。然后我尝试了这个,

<?xml version="1.0" standalone="yes"?>
<NewDataSet>
</NewDataSet>

但这会创建一个没有表的DataSet。如何使用1个名为“Table”的表创建一个DataSet,其中包含1列,但现在是行?

1 个答案:

答案 0 :(得分:2)

你做不到。 ReadXml和WriteXml只读/写数据,而不是整个数据集/ datatable / columns / etc-schema的结构。

我的建议是首先使用函数ReadXmlSchema从单独的模式文件中读取模式,然后再读取数据文件。

您的架构可能如下所示:

<?xml version="1.0" standalone="yes"?>
<xs:schema id="MyDataSet" xmlns="" xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:msdata="urn:schemas-microsoft-com:xml-msdata">
  <xs:element name="MyDataSet" msdata:IsDataSet="true" msdata:UseCurrentLocale="true">
    <xs:complexType>
      <xs:choice minOccurs="0" maxOccurs="unbounded">
        <xs:element name="MyDataTable">
          <xs:complexType>
            <xs:sequence>
              <xs:element name="MyDataColumn" type="xs:string" minOccurs="0" />
            </xs:sequence>
          </xs:complexType>
        </xs:element>
      </xs:choice>
    </xs:complexType>
  </xs:element>
</xs:schema>