C#中DataTable动态添加行和删除行的问题?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C#中DataTable动态添加行和删除行的问题?相关的知识,希望对你有一定的参考价值。

我想创建一个DataTable,有如下几列,商品ID,商品名称,商品数量,有个按钮的单击事件,每点一次按钮,会从3个文本框中取值为DataTable添加一行数据,请高手支招,怎么实现?
点击3次,DataTable就有3行数据,最好是完整的代码,谢谢```
我看过大多数方法都是点击后确实能添加一行数据,但问题是点击第二次的时候,新添加的行会把原行覆盖,也就是无论点击多少次,都只有一行数据

参考技术A datatable dt = new datatable();
dt.columns.add("id");
dt.columns.add("商品名称");
dt.columns.add("商品名称");

datarow row = dt.newrow();

row[0]="";
row[1]="";
row[2]="";

dt.rows.add(row);
参考技术B dt.rows.add(row);---这个才算添加完毕了.
点击三次,你每次都得有dt.rows.add(row);
参考技术C private void Page_Load(object sender, System.EventArgs e)

if( ! this.Page.IsPostBack)

dt = new DataTable();
dt.Columns.Add("Id");
dt.Columns.Add("CommodityName");
dt.Columns.Add("CommodityNumber");
this.ViewState.Add("dt", dt);



private void Button1_Click(object sender, System.EventArgs e)

DataTable dt = (DataTable)this.ViewState["dt"];
DataRow dr = dt.NewRow();
dr["Id"] = int.Parse(this.TextBox1.Text);
dr["CommodityName"] = this.TextBox2.Text;
dr["CommodityNumber"] = int.Parse(this.TextBox3.Text);
dt.Rows.Add(dr);
dt.AcceptChanges();

可以实现每点击按钮一次,DataTable就在原有的基础上增添一行。本回答被提问者采纳

C#中删除DataTable中的行的方法

1、在C#中,如果要删除DataTable中的某一行,大约有以下几种办法:

•使用DataTable.Rows.Remove(DataRow),或者DataTable.Rows.RemoveAt(index);可以直接删除行
•datatable.Rows[i].Delete()。Delete()之后需要datatable.AccepteChanges()方法确认完全删除,因为Delete()只是将相应列的状态标志为删除,还可以通过datatable.RejectChanges()回滚,使该行取消删除。
•在删除DataTable中的行的时候,每删除一行,DataTable中所有行的索引都会发生改变。在循环删除DataTable.Row的时候不能使用foreach。使用foreach进行循环的时候,是不允许Table有删除和添加操作的。
•如果是按某列为条件进行删除,则每删完一行,整个Table的index就会立即发生变化,等于Table已经变成了一个新的表。但是索引却已经加1了。于是会造成第一列永远匹配不到。因此,每删除完一行,要跟着判断第一行是否满足删除条件。
•如果要删除DataTable中的多行,应该采用倒序循环DataTable.Rows。因为正序删除时索引会发生变化。程式发生异常,很难预料后果。(不要在循环里使用myDataTable.Rows.RemoveAt(i).因为每删除一行后.i的值会增加,但行数会是减少了.这么做一定会出错.因此要遍历数据,使用Remove方式时,要倒序的遍历)

int count = ds.Tables[0].Rows.Count;
for (int i = count -1; i >=0; i--)

ds.Tables[0].Rows.RemoveAt(i);
}

 

总结:

delete和remove

•Delete的使用是 datatable.Rows[i].Delete();
•Remove的使用是datatable.Rows.Remove(datatable.Rows[i]);
•这两个的区别是,使用delete后,只是该行被标记为deleted,但是还存在,用Rows.Count来获取行数时,还是删除之前的行数.需要使用datatable.AcceptChanges()方法来提交修改.
而Remove方法则是直接删除.(有时候发现使用ds.Tables[0].Rows[i].Delete();数据行也被直接删除了,原因是在创建datatable时没有执行AcceptChanges这个方法,那么在delete时,不会标记,会直接删除掉。)
•如果在for循环里删除行的话,最好是使用delete方法,不然会出现count变化的情况.循环完后再使用AcceptChanges()方法提交修改,删除掉标记为deleted的行

以上是关于C#中DataTable动态添加行和删除行的问题?的主要内容,如果未能解决你的问题,请参考以下文章

C#中删除DataTable中的行的方法

C#中DataTable删除行后 GrdData.Rows.Count行数没变,求解:

c#中datatable怎么添加列名

Datatable删除行的Delete和Remove方法

c# datatable 隐藏行?

C#如何获取datatable指定行的值