我目前正在使用此
从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列,但现在是行?
答案 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>