C # - DataTable внутри DataTable - PullRequest
0 голосов
/ 01 июня 2018

В Blue Prism (BP) есть нечто, называемое Collection, которое в основном представляет собой DataTable в C #.В BP вы можете иметь коллекцию внутри коллекции.У меня вопрос, можете ли вы иметь DataTable в DataTable в C #?

Вот мой код ниже:

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

1 Ответ

0 голосов
/ 01 июня 2018

Проблема заключается в вашем коде, который определяет схему DataTable, в частности, где вы определяете столбец для InnerDataTable .

DataColumn dc4 = new DataColumn("InnerDataTable");

Конструктор инициализируетэкземпляр класса 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; }
}

, а затем определить InnerDataTable столбца typeof(InnerTable).

DataColumn dc4 = new DataColumn("InnerDataTable", typeof(InnerTable));

Я поставил полное решение на dotnetfiddle .

...