首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >C# - DataTable在DataTable中

C# - DataTable在DataTable中
EN

Stack Overflow用户
提问于 2018-06-01 01:35:45
回答 1查看 886关注 0票数 2

在蓝色棱镜(BP)中,有一种叫做“集合”的东西,基本上是DataTable In C#。在BP中,您可以在集合中拥有一个集合。我的问题是,您能在DataTable中的DataTable中使用C#吗?

下面是我的代码:

代码语言:javascript
复制
//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#中根本不可能?

这是控制台中的输出,我希望

代码语言:javascript
复制
<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>

但这是,实际上显示了

代码语言:javascript
复制
<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>
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-06-01 02:37:05

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

代码语言:javascript
复制
DataColumn dc4 = new DataColumn("InnerDataTable");

构造函数DataColumn类的实例初始化为string类型。如果希望类型为DataTable,则希望类型为typeof(DataTable)

代码语言:javascript
复制
DataColumn dc4 = new DataColumn("InnerDataTable", typeof(DataTable));

但是,将InnerDataTable定义为DataTable类型不会得到您期望的输出。您需要定义一个类来建模InnerDataTable。

代码语言:javascript
复制
public class InnerTable
{
    public string TestOne { get; set; }
    public string TestTwo { get; set; }
}

然后定义InnerDataTable列的typeof(InnerTable)

代码语言:javascript
复制
DataColumn dc4 = new DataColumn("InnerDataTable", typeof(InnerTable));

我已经在多管乐器上提出了完整的解决方案。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50634951

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档