gpt4 book ai didi

C# - DataTable 中的 DataTable

转载 作者:行者123 更新时间:2023-11-30 23:02:05 27 4
gpt4 key购买 nike

在 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>

最佳答案

问题出在您定义 DataTable 架构的代码中,特别是您为 InnerDataTable 定义列的位置。

DataColumn dc4 = new DataColumn("InnerDataTable");

constructorDataColumn 类的实例初始化为字符串类型。如果您希望类型为 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 上发布了完整的解决方案.

关于C# - DataTable 中的 DataTable,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50634951/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com