本文整理汇总了C#中DataTable.ReadXmlSchema方法的典型用法代码示例。如果您正苦于以下问题:C# DataTable.ReadXmlSchema方法的具体用法?C# DataTable.ReadXmlSchema怎么用?C# DataTable.ReadXmlSchema使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类DataTable
的用法示例。
在下文中一共展示了DataTable.ReadXmlSchema方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: XmlSchemaTest5
public void XmlSchemaTest5()
{
MakeParentTable();
MakeChildTable();
MakeSecondChildTable();
MakeDataRelation();
//Write
using (FileStream stream = new FileStream(_tempFile, FileMode.Create))
{
_childTable.WriteXmlSchema(stream);
}
//Read
DataTable table = new DataTable(_childTable.TableName);
using (FileStream stream = new FileStream(_tempFile, FileMode.Open))
{
table.ReadXmlSchema(stream);
}
//Check Properties of the table
Assert.Equal(string.Empty, table.Namespace);
Assert.Null(table.DataSet);
Assert.Equal(3, table.Columns.Count);
Assert.Equal(0, table.Rows.Count);
Assert.Equal(false, table.CaseSensitive);
Assert.Equal("ChildTable", table.TableName);
Assert.Equal(string.Empty, table.Prefix);
Assert.Equal(1, table.Constraints.Count);
Assert.Equal("Constraint1", table.Constraints[0].ToString());
Assert.Equal(typeof(UniqueConstraint), table.Constraints[0].GetType());
Assert.Equal(0, table.ParentRelations.Count);
Assert.Equal(0, table.ChildRelations.Count);
Assert.Equal(0, table.PrimaryKey.Length);
//First Column
DataColumn col = table.Columns[0];
Assert.Equal(true, col.AllowDBNull);
Assert.Equal(true, col.AutoIncrement);
Assert.Equal(0, col.AutoIncrementSeed);
Assert.Equal(1, col.AutoIncrementStep);
Assert.Equal("Element", col.ColumnMapping.ToString());
Assert.Equal("ChildID", col.ColumnName);
Assert.Equal(typeof(int), col.DataType);
Assert.Equal(string.Empty, col.DefaultValue.ToString());
Assert.Equal(false, col.DesignMode);
Assert.Equal("System.Data.PropertyCollection", col.ExtendedProperties.ToString());
Assert.Equal(-1, col.MaxLength);
Assert.Equal(0, col.Ordinal);
Assert.Equal(string.Empty, col.Prefix);
Assert.Equal("ChildTable", col.Table.ToString());
Assert.Equal(true, col.Unique);
//Second Column
col = table.Columns[1];
Assert.Equal(true, col.AllowDBNull);
Assert.Equal(false, col.AutoIncrement);
Assert.Equal(0, col.AutoIncrementSeed);
Assert.Equal(1, col.AutoIncrementStep);
Assert.Equal("Element", col.ColumnMapping.ToString());
Assert.Equal("ChildItem", col.Caption);
Assert.Equal("ChildItem", col.ColumnName);
Assert.Equal(typeof(string), col.DataType);
Assert.Equal(string.Empty, col.DefaultValue.ToString());
Assert.Equal(false, col.DesignMode);
Assert.Equal("System.Data.PropertyCollection", col.ExtendedProperties.ToString());
Assert.Equal(-1, col.MaxLength);
Assert.Equal(1, col.Ordinal);
Assert.Equal(string.Empty, col.Prefix);
Assert.Equal("ChildTable", col.Table.ToString());
Assert.Equal(false, col.Unique);
//Third Column
col = table.Columns[2];
Assert.Equal(true, col.AllowDBNull);
Assert.Equal(false, col.AutoIncrement);
Assert.Equal(0, col.AutoIncrementSeed);
Assert.Equal(1, col.AutoIncrementStep);
Assert.Equal("Element", col.ColumnMapping.ToString());
Assert.Equal("ParentID", col.Caption);
Assert.Equal("ParentID", col.ColumnName);
Assert.Equal(typeof(int), col.DataType);
Assert.Equal(string.Empty, col.DefaultValue.ToString());
Assert.Equal(false, col.DesignMode);
Assert.Equal("System.Data.PropertyCollection", col.ExtendedProperties.ToString());
Assert.Equal(-1, col.MaxLength);
Assert.Equal(2, col.Ordinal);
Assert.Equal(string.Empty, col.Prefix);
Assert.Equal("ChildTable", col.Table.ToString());
Assert.Equal(false, col.Unique);
}
示例2: XmlSchemaTest6
public void XmlSchemaTest6()
{
MakeParentTable();
using (FileStream stream = new FileStream(_tempFile, FileMode.Create))
{
_parentTable.WriteXmlSchema(stream);
}
DataTable table = new DataTable();
DataSet ds = new DataSet();
ds.Tables.Add(table);
using (FileStream stream = new FileStream(_tempFile, FileMode.Open))
{
try
{
table.ReadXmlSchema(stream);
Assert.False(true);
}
catch (ArgumentException ex)
{
// DataTable 'Table1' does not match
// to any DataTable in source
Assert.Equal(typeof(ArgumentException), ex.GetType());
Assert.Null(ex.InnerException);
Assert.NotNull(ex.Message);
Assert.True(ex.Message.IndexOf("'Table1'") != -1);
Assert.Null(ex.ParamName);
}
}
}
示例3: XmlSchemaTest1
public void XmlSchemaTest1()
{
MakeParentTable();
//Detach the table from the DataSet
_dataSet.Tables.Remove(_parentTable);
//Write
using (FileStream stream = new FileStream(_tempFile, FileMode.Create))
{
_parentTable.WriteXmlSchema(stream);
}
//Read
DataTable table = new DataTable();
using (FileStream stream = new FileStream(_tempFile, FileMode.Open))
{
table.ReadXmlSchema(stream);
}
VerifyTableSchema(table, _parentTable.TableName, _parentTable.DataSet);
}
示例4: XmlSchemaTest3
public void XmlSchemaTest3()
{
//Write
MakeParentTable();
using (FileStream stream = new FileStream(_tempFile, FileMode.Create))
{
_parentTable.WriteXmlSchema(stream);
}
//Read
DataTable table = new DataTable();
using (FileStream stream = new FileStream(_tempFile, FileMode.Open))
{
table.ReadXmlSchema(stream);
}
VerifyTableSchema(table, _parentTable.TableName, null);
}
示例5: ReadXmlSchemeWithScheme
public void ReadXmlSchemeWithScheme()
{
const string xml = @"<CustomElement>
<xs:schema id='NewDataSet' xmlns='' xmlns:xs='http://www.w3.org/2001/XMLSchema' xmlns:msdata='urn:schemas-microsoft-com:xml-msdata'>
<xs:element name='NewDataSet' msdata:IsDataSet='true' msdata:MainDataTable='row' msdata:Locale=''>
<xs:complexType>
<xs:choice minOccurs='0' maxOccurs='unbounded'>
<xs:element name='row' msdata:Locale=''>
<xs:complexType>
<xs:sequence>
<xs:element name='Text' type='xs:string' minOccurs='0' />
</xs:sequence>
</xs:complexType>
</xs:element>
</xs:choice>
</xs:complexType>
</xs:element>
</xs:schema>
</CustomElement>";
using (var s = new StringReader(xml))
{
DataTable dt = new DataTable();
dt.ReadXmlSchema(s);
Assert.Equal("row", dt.TableName);
}
}
示例6: ReadXmlSchemeWithBadScheme
public void ReadXmlSchemeWithBadScheme()
{
const string xml = @"<CustomElement>
<xs:schema id='NewDataSet' xmlns='' xmlns:xs='http://www.w3.org/2001/BAD' xmlns:msdata='urn:schemas-microsoft-com:xml-msdata'>
</xs:schema>
</CustomElement>";
Assert.Throws<ArgumentException>(() =>
{
using (var s = new StringReader(xml))
{
DataTable dt = new DataTable();
dt.ReadXmlSchema(s);
}
});
}
示例7: ReadWriteXmlSchemaExp_TableNameConflict
public void ReadWriteXmlSchemaExp_TableNameConflict()
{
DataTable dtw = new DataTable("Table1");
StringWriter writer1 = new StringWriter();
dtw.WriteXmlSchema(writer1);
DataTable dtr = new DataTable("Table2");
StringReader reader1 = new StringReader(writer1.ToString());
try
{
dtr.ReadXmlSchema(reader1);
Assert.False(true);
}
catch (ArgumentException)
{
}
}
示例8: ReadXmlSchema_2
public void ReadXmlSchema_2()
{
DataTable dt = new DataTable();
string xmlData = string.Empty;
xmlData += "<?xml version=\"1.0\"?>";
xmlData += "<xs:schema id=\"SiteConfiguration\" targetNamespace=\"http://tempuri.org/PortalCfg.xsd\" xmlns:mstns=\"http://tempuri.org/PortalCfg.xsd\" xmlns=\"http://tempuri.org/PortalCfg.xsd\" xmlns:xs=\"http://www.w3.org/2001/XMLSchema\" xmlns:msdata=\"urn:schemas-microsoft-com:xml-msdata\" attributeFormDefault=\"qualified\" elementFormDefault=\"qualified\">";
xmlData += "<xs:element name=\"SiteConfiguration\" msdata:IsDataSet=\"true\" msdata:EnforceConstraints=\"False\">";
xmlData += "<xs:complexType>";
xmlData += "<xs:choice minOccurs=\"0\" maxOccurs=\"unbounded\">";
xmlData += "<xs:element name=\"Tab\">";
xmlData += "<xs:complexType>";
xmlData += "<xs:sequence>";
xmlData += "<xs:element name=\"Module\" minOccurs=\"0\" maxOccurs=\"unbounded\">";
xmlData += "<xs:complexType>";
xmlData += "<xs:attribute name=\"ModuleId\" form=\"unqualified\" type=\"xs:int\" />";
xmlData += "</xs:complexType>";
xmlData += "</xs:element>";
xmlData += "</xs:sequence>";
xmlData += "<xs:attribute name=\"TabId\" form=\"unqualified\" type=\"xs:int\" />";
xmlData += "</xs:complexType>";
xmlData += "</xs:element>";
xmlData += "</xs:choice>";
xmlData += "</xs:complexType>";
xmlData += "<xs:key name=\"TabKey\" msdata:PrimaryKey=\"true\">";
xmlData += "<xs:selector xpath=\".//mstns:Tab\" />";
xmlData += "<xs:field xpath=\"@TabId\" />";
xmlData += "</xs:key>";
xmlData += "<xs:key name=\"ModuleKey\" msdata:PrimaryKey=\"true\">";
xmlData += "<xs:selector xpath=\".//mstns:Module\" />";
xmlData += "<xs:field xpath=\"@ModuleID\" />";
xmlData += "</xs:key>";
xmlData += "</xs:element>";
xmlData += "</xs:schema>";
dt.ReadXmlSchema(new StringReader(xmlData));
}
示例9: WriteXmlSchema_Relations_ForeignKeys
public void WriteXmlSchema_Relations_ForeignKeys()
{
MemoryStream ms1 = null;
MemoryStream ms2 = null;
MemoryStream msA = null;
MemoryStream msB = null;
DataSet ds1 = new DataSet();
DataTable table1 = ds1.Tables.Add("Table 1");
DataTable table2 = ds1.Tables.Add("Table 2");
DataColumn col1_1 = table1.Columns.Add("col 1", typeof(int));
DataColumn col1_2 = table1.Columns.Add("col 2", typeof(int));
DataColumn col1_3 = table1.Columns.Add("col 3", typeof(int));
DataColumn col1_4 = table1.Columns.Add("col 4", typeof(int));
DataColumn col1_5 = table1.Columns.Add("col 5", typeof(int));
DataColumn col1_6 = table1.Columns.Add("col 6", typeof(int));
DataColumn col1_7 = table1.Columns.Add("col 7", typeof(int));
DataColumn col2_1 = table2.Columns.Add("col 1", typeof(int));
DataColumn col2_2 = table2.Columns.Add("col 2", typeof(int));
DataColumn col2_3 = table2.Columns.Add("col 3", typeof(int));
DataColumn col2_4 = table2.Columns.Add("col 4", typeof(int));
DataColumn col2_5 = table2.Columns.Add("col 5", typeof(int));
DataColumn col2_6 = table2.Columns.Add("col 6", typeof(int));
DataColumn col2_7 = table2.Columns.Add("col 7", typeof(int));
ds1.Relations.Add("rel 1",
new DataColumn[] { col1_1, col1_2 },
new DataColumn[] { col2_1, col2_2 },
false);
ds1.Relations.Add("rel 2",
new DataColumn[] { col1_3, col1_4 },
new DataColumn[] { col2_3, col2_4 },
true);
table2.Constraints.Add("fk 1",
new DataColumn[] { col1_5, col1_6 },
new DataColumn[] { col2_5, col2_6 });
table1.Constraints.Add("fk 2",
new DataColumn[] { col2_5, col2_6 },
new DataColumn[] { col1_5, col1_6 });
table1.Constraints.Add("pk 1", col1_7, true);
table2.Constraints.Add("pk 2", col2_7, true);
ms1 = new MemoryStream();
ds1.Tables[0].WriteXmlSchema(ms1);
ms2 = new MemoryStream();
ds1.Tables[1].WriteXmlSchema(ms2);
msA = new MemoryStream(ms1.GetBuffer());
DataTable dtA = new DataTable();
dtA.ReadXmlSchema(msA);
msB = new MemoryStream(ms2.GetBuffer());
DataTable dtB = new DataTable();
dtB.ReadXmlSchema(msB);
Assert.Equal(3, dtA.Constraints.Count);
Assert.Equal(2, dtB.Constraints.Count);
Assert.True(dtA.Constraints.Contains("pk 1"));
Assert.True(dtA.Constraints.Contains("Constraint1"));
Assert.True(dtA.Constraints.Contains("Constraint2"));
Assert.True(dtB.Constraints.Contains("pk 2"));
Assert.True(dtB.Constraints.Contains("Constraint1"));
}
示例10: ReadWriteXmlSchemaExp_NoRootElmnt
public void ReadWriteXmlSchemaExp_NoRootElmnt()
{
MemoryStream ms = new MemoryStream();
DataTable dtr = new DataTable();
try
{
dtr.ReadXmlSchema(ms);
Assert.False(true);
}
catch (XmlException)
{
}
}
示例11: ReadXmlSchema_ByXmlReader
public void ReadXmlSchema_ByXmlReader()
{
DataSet ds1 = new DataSet();
ds1.Tables.Add(DataProvider.CreateParentDataTable());
ds1.Tables.Add(DataProvider.CreateChildDataTable());
StringWriter sw1 = new StringWriter();
XmlTextWriter xmlTW1 = new XmlTextWriter(sw1);
StringWriter sw2 = new StringWriter();
XmlTextWriter xmlTW2 = new XmlTextWriter(sw2);
//write xml file, schema only
ds1.Tables[0].WriteXmlSchema(xmlTW1);
xmlTW1.Flush();
ds1.Tables[1].WriteXmlSchema(xmlTW2);
xmlTW2.Flush();
StringReader sr1 = new StringReader(sw1.ToString());
XmlTextReader xmlTR1 = new XmlTextReader(sr1);
StringReader sr2 = new StringReader(sw2.ToString());
XmlTextReader xmlTR2 = new XmlTextReader(sr2);
//copy both data and schema
//DataSet ds2 = new DataSet ();
DataTable dt1 = new DataTable();
DataTable dt2 = new DataTable();
//ds2.ReadXmlSchema (xmlTR);
dt1.ReadXmlSchema(xmlTR1);
dt2.ReadXmlSchema(xmlTR2);
//check xml schema
// ReadXmlSchema - Tables count
//Assert.Equal (ds2.Tables.Count, ds1.Tables.Count);
// ReadXmlSchema - Tables 0 Col count
Assert.Equal(ds1.Tables[0].Columns.Count, dt1.Columns.Count);
// ReadXmlSchema - Tables 1 Col count
Assert.Equal(ds1.Tables[1].Columns.Count, dt2.Columns.Count);
//check some colummns types
// ReadXmlSchema - Tables 0 Col type
Assert.Equal(ds1.Tables[0].Columns[0].GetType(), dt1.Columns[0].GetType());
// ReadXmlSchema - Tables 1 Col type
Assert.Equal(ds1.Tables[1].Columns[3].GetType(), dt2.Columns[3].GetType());
//check that no data exists
// ReadXmlSchema - Table 1 row count
Assert.Equal(0, dt1.Rows.Count);
// ReadXmlSchema - Table 2 row count
Assert.Equal(0, dt2.Rows.Count);
}
示例12: ReadWriteXmlSchema_ByFileName
public void ReadWriteXmlSchema_ByFileName()
{
string sTempFileName1 = Path.Combine(Path.GetTempPath(), "tmpDataSet_ReadWriteXml_43899-1.xml");
string sTempFileName2 = Path.Combine(Path.GetTempPath(), "tmpDataSet_ReadWriteXml_43899-2.xml");
DataSet ds1 = new DataSet();
ds1.Tables.Add(DataProvider.CreateParentDataTable());
ds1.Tables.Add(DataProvider.CreateChildDataTable());
ds1.Tables[0].WriteXmlSchema(sTempFileName1);
ds1.Tables[1].WriteXmlSchema(sTempFileName2);
DataTable dt1 = new DataTable();
DataTable dt2 = new DataTable();
dt1.ReadXmlSchema(sTempFileName1);
dt2.ReadXmlSchema(sTempFileName2);
Assert.Equal(ds1.Tables[0].Columns.Count, dt1.Columns.Count);
Assert.Equal(ds1.Tables[1].Columns.Count, dt2.Columns.Count);
Assert.Equal(ds1.Tables[0].Columns[0].GetType(), dt1.Columns[0].GetType());
Assert.Equal(ds1.Tables[1].Columns[3].GetType(), dt2.Columns[3].GetType());
Assert.Equal(0, dt1.Rows.Count);
Assert.Equal(0, dt2.Rows.Count);
File.Delete(sTempFileName1);
File.Delete(sTempFileName2);
}
示例13: ReadXmlSchema_ByStream
public void ReadXmlSchema_ByStream()
{
DataSet ds1 = new DataSet();
ds1.Tables.Add(DataProvider.CreateParentDataTable());
ds1.Tables.Add(DataProvider.CreateChildDataTable());
MemoryStream ms1 = new MemoryStream();
MemoryStream ms2 = new MemoryStream();
//write xml schema only
//ds1.WriteXmlSchema (ms);
ds1.Tables[0].WriteXmlSchema(ms1);
ds1.Tables[1].WriteXmlSchema(ms2);
MemoryStream ms11 = new MemoryStream(ms1.GetBuffer());
MemoryStream ms22 = new MemoryStream(ms2.GetBuffer());
//copy schema
//DataSet ds2 = new DataSet ();
DataTable dt1 = new DataTable();
DataTable dt2 = new DataTable();
//ds2.ReadXmlSchema (ms1);
dt1.ReadXmlSchema(ms11);
dt2.ReadXmlSchema(ms22);
//check xml schema
// ReadXmlSchema - Tables count
//Assert.Equal (ds2.Tables.Count, ds1.Tables.Count);
// ReadXmlSchema - Tables 0 Col count
Assert.Equal(ds1.Tables[0].Columns.Count, dt1.Columns.Count);
// ReadXmlSchema - Tables 1 Col count
Assert.Equal(ds1.Tables[1].Columns.Count, dt2.Columns.Count);
//check some colummns types
// ReadXmlSchema - Tables 0 Col type
Assert.Equal(ds1.Tables[0].Columns[0].GetType(), dt1.Columns[0].GetType());
// ReadXmlSchema - Tables 1 Col type
Assert.Equal(ds1.Tables[1].Columns[3].GetType(), dt2.Columns[3].GetType());
//check that no data exists
// ReadXmlSchema - Table 1 row count
Assert.Equal(0, dt1.Rows.Count);
// ReadXmlSchema - Table 2 row count
Assert.Equal(0, dt2.Rows.Count);
}
示例14: XmlSchemaTest7
public void XmlSchemaTest7()
{
DataTable table = new DataTable();
try
{
table.ReadXmlSchema(string.Empty);
Assert.False(true);
}
catch (ArgumentException ex)
{
// The URL cannot be empty
Assert.Equal(typeof(ArgumentException), ex.GetType());
Assert.Null(ex.InnerException);
Assert.NotNull(ex.Message);
//Assert.Equal ("url", ex.ParamName);
}
}
示例15: ReadXmlSchemeWithoutScheme
public void ReadXmlSchemeWithoutScheme()
{
const string xml = @"<CustomElement />";
using (var s = new StringReader(xml))
{
DataTable dt = new DataTable();
dt.ReadXmlSchema(s);
Assert.Equal("", dt.TableName);
}
}