如何在c#中创建一个数据表?

我是这样做的:

 DataTable dt = new DataTable();
 dt.clear();
 dt.Columns.Add("Name");
 dt.Columns.Add("Marks");

我如何看到数据表的结构?

现在我想为Name添加ravi,为Marks添加500。我该怎么做呢?


当前回答

创建datatabe的2列:名称和标记 IList columns = new List() {"Name", "Marks"}; Datatabel dt = new Datatable(); Foreach(列中的字符串列) dtSalesOrder.Columns。添加(列,typeof (string)); 向数据表中添加数据 dt.Rows.Add(“拉”,“500”);

其他回答

您可以使用DataRow编写一行代码。添加(params object[] values)而不是四行。

dt.Rows.Add("Ravi", "500");

在创建新的DataTable对象时,似乎没有必要在下一条语句中清除DataTable。你也可以使用DataTable.Columns.AddRange来添加on语句的列。完整的代码将。

DataTable dt = new DataTable();
dt.Columns.AddRange(new DataColumn[] { new DataColumn("Name"), new DataColumn("Marks") });     
dt.Rows.Add("Ravi", "500");

除了其他答案。

如果你控制数据表的结构,有一个添加行的快捷方式:

//假设您有一个数据表,定义为示例中的dt dt.Rows。添加(“名称”、“商标”);

add()方法有一个重载,它接受一个对象的参数数组。此方法允许您根据需要传递任意数量的值,但它们必须与表中定义的列的顺序相同。

因此,虽然这是一种方便的添加行数据的方法,但使用它可能有风险。如果表结构改变,代码将失败。

问题1:如何在c#中创建数据表?

回答1:

DataTable dt = new DataTable(); // DataTable created

// Add columns in your DataTable
dt.Columns.Add("Name");
dt.Columns.Add("Marks");

注意:创建数据表后不需要Clear()。

问题2:如何添加行?

答案2:增加一行:

dt.Rows.Add("Ravi","500");

添加多行:使用ForEach循环

DataTable dt2 = (DataTable)Session["CartData"]; // This DataTable contains multiple records
foreach (DataRow dr in dt2.Rows)
{
    dt.Rows.Add(dr["Name"], dr["Marks"]);
}

目前最简单的方法是创建一个DtaTable

DataTable table = new DataTable
{
    Columns = {
        "Name", // typeof(string) is implied
        {"Marks", typeof(int)}
    },
    TableName = "MarksTable" //optional
};
table.Rows.Add("ravi", 500);

你也可以传入一个对象数组,像这样:

DataTable dt = new DataTable();
dt.Clear();
dt.Columns.Add("Name");
dt.Columns.Add("Marks");
object[] o = { "Ravi", 500 };
dt.Rows.Add(o);

甚至:

dt.Rows.Add(new object[] { "Ravi", 500 });