C# 如何向datatable添加数据

C# 如何向datatable添加数据,c#,datatable,C#,Datatable,我想在c#中的循环中向datatable添加数据,但我不能。 我使用这段代码,但它运行了1次,而不是更多。当i=2时不起作用。 请帮忙 DataTable dt = new DataTable(); dt.Columns.Add("ProductId"); dt.Columns.Add("ProductTotalPrice"); DataRow dr = dt.NewRow(); for (int i = 0; i < 10; i++) { dr["ProductId"] = i

我想在c#中的循环中向datatable添加数据,但我不能。 我使用这段代码,但它运行了1次,而不是更多。当
i=2时
不起作用。 请帮忙

DataTable dt = new DataTable();
dt.Columns.Add("ProductId");
dt.Columns.Add("ProductTotalPrice");
DataRow dr = dt.NewRow();

for (int i = 0; i < 10; i++)
{
    dr["ProductId"] = i.ToString();
    dr["ProductTotalPrice"] = (i*1000).ToString();
    dt.Rows.Add(dr);
}
DataTable dt=newdatatable();
添加(“产品ID”);
dt.列。添加(“产品总价”);
DataRow dr=dt.NewRow();
对于(int i=0;i<10;i++)
{
dr[“ProductId”]=i.ToString();
dr[“ProductTotalPrice”]=(i*1000).ToString();
dt.Rows.Add(dr);
}
用于(int i=0;i<10;i++)
{
dr=dt.NewRow();
dr[“ProductId”]=i.ToString();
dr[“ProductTotalPrice”]=(i*1000).ToString();
dt.Rows.Add(dr);
}
应该有用


每次需要添加不同的数据行时。您正在尝试添加相同的值。

这是因为您只创建了一个
DataRow
外部循环,因此实际上您在该行中用新值过度写入旧值。您的行创建应该在循环内,因此每次迭代都会有新行,如

DataTable dt = new DataTable();
dt.Columns.Add("ProductId");
dt.Columns.Add("ProductTotalPrice");
DataRow dr = null;

for (int i = 0; i < 10; i++)
{
    dr = dt.NewRow(); // have new row on each iteration
    dr["ProductId"] = i.ToString();
    dr["ProductTotalPrice"] = (i*1000).ToString();
    dt.Rows.Add(dr);
}
DataTable dt=newdatatable();
添加(“产品ID”);
dt.列。添加(“产品总价”);
数据行dr=null;
对于(int i=0;i<10;i++)
{
dr=dt.NewRow();//每次迭代都有新行
dr[“ProductId”]=i.ToString();
dr[“ProductTotalPrice”]=(i*1000).ToString();
dt.Rows.Add(dr);
}

还有一种简单的方法:

for (int i = 0; i < 10; i++)
{
    dt.Rows.Add(i, i * 1000);
}
for(int i=0;i<10;i++)
{
dt.行加(i,i*1000);
}

为什么它应该工作?您可能还希望在回答中包含该解释。
for (int i = 0; i < 10; i++)
{
    dt.Rows.Add(i, i * 1000);
}