在Blue Prism(BP)中,有一种称为Collection的东西,它基本上是C#中的DataTable。在BP中,您可以在集合中拥有集合。我的问题是,你能在C#中的DataTable中拥有一个DataTable吗?
以下是我的代码:
//inner datatable
DataTable dt2 = new DataTable();
DataColumn dc5 = new DataColumn("TestOne");
DataColumn dc6 = new DataColumn("TestTwo");
dt2.Columns.Add(dc5);
dt2.Columns.Add(dc6);
dt2.Rows.Add("Value1", "Value2");
//outer datatable
DataTable dt = new DataTable();
DataColumn dc1 = new DataColumn("Name");
DataColumn dc2 = new DataColumn("Age");
DataColumn dc3 = new DataColumn("Gender");
DataColumn dc4 = new DataColumn("InnerDataTable");
dt.Columns.Add(dc1);
dt.Columns.Add(dc2);
dt.Columns.Add(dc3);
dt.Columns.Add(dc4);
//adding of inner datatable to outer datatable
dt.Rows.Add("John", "23", "Male", dt2);
dt.Rows.Add("Gretchen", "25", "Female", dt2);
dt.Rows.Add("Jordan", "28", "Male", dt2);
DataSet ds = new DataSet();
ds.Tables.Add(dt);
string xml = ds.GetXml();
Console.WriteLine(xml);
Console.ReadLine();
最后,我将DataSet解析为XML,但InnerDataTable列没有任何值。我在这里做错了什么,或者这在C#中是不可能的?
这是控制台中输出 我想要 :
<NewDataSet>
<Table1>
<Name>John</Name>
<Age>23</Age>
<Gender>Male</Gender>
<InnerDataTable>
<TestOne>Value1</TestOne>
<TestTwo>Value2</TestTwo>
</InnerDataTable>
</Table1>
<Table1>
<Name>Gretchen</Name>
<Age>25</Age>
<Gender>Female</Gender>
<InnerDataTable>
<TestOne>Value1<TestOne>
<TestTwo>Value2</TestTwo>
</InnerDataTable>
</Table1>
<Table1>
<Name>Jordan</Name>
<Age>28</Age>
<Gender>Male</Gender>
<InnerDataTable>
<TestOne>Value1<TestOne>
<TestTwo>Value2</TestTwo>
</InnerDataTable>
</Table1>
</NewDataSet>
但这是 实际显示的内容 :
<NewDataSet>
<Table1>
<Name>John</Name>
<Age>23</Age>
<Gender>Male</Gender>
<InnerDataTable />
</Table1>
<Table1>
<Name>Gretchen</Name>
<Age>25</Age>
<Gender>Female</Gender>
<InnerDataTable />
</Table1>
<Table1>
<Name>Jordan</Name>
<Age>28</Age>
<Gender>Male</Gender>
<InnerDataTable />
</Table1>
</NewDataSet>
答案 0 :(得分:2)
问题在于定义DataTable架构的代码,特别是在为 InnerDataTable 定义列的位置。
DataColumn dc4 = new DataColumn("InnerDataTable");
constructor将DataColumn
类的实例初始化为类型字符串。如果您希望类型为DataTable
,那么您希望类型为typeof(DataTable)
。
DataColumn dc4 = new DataColumn("InnerDataTable", typeof(DataTable));
但是,将 InnerDataTable 定义为DataTable
类型将无法获得您期望的输出。您需要定义一个类来模拟 InnerDataTable 。
public class InnerTable
{
public string TestOne { get; set; }
public string TestTwo { get; set; }
}
然后定义typeof(InnerTable)
的 InnerDataTable 列。
DataColumn dc4 = new DataColumn("InnerDataTable", typeof(InnerTable));
我在dotnetfiddle提出了完整的解决方案。