我想在DataTable中添加一行,该行具有一个具有自动增量属性的数据列.
DataTable tblproduct = new DataTable();
DataColumn CartItemId = new DataColumn();
CartItemId.ColumnName = "CartItemId";
CartItemId.DataType = System.Type.GetType("System.Int32");
CartItemId.AutoIncrement = true;
CartItemId.AutoIncrementSeed = 1;
CartItemId.AutoIncrementStep = 1;
CartItemId.ReadOnly = true;
CartItemId.Unique = true;
tblproduct.Columns.Add(CartItemId);
tblproduct.Columns.Add("CampaignId", typeof(int));
tblproduct.Columns.Add("SubCatId", typeof(int));
tblproduct.Columns.Add("Size", typeof(string));
tblproduct.Columns.Add("Qty", typeof(int));
tblproduct.Rows.Add(3, 345,"Hello", 1);
tblproduct.Rows.Add(5, 3455,"Hecfghhgdfllo", 8);
Run Code Online (Sandbox Code Playgroud)
我不想在Autoincreamented列中插入值.它应该是自动生成的值,但上面的代码对我不起作用.
添加行时,请尝试类似的操作
DataRow dr = tblproduct.NewRow();
dr["CampaignId"] = 3;
dr["SubCatId"] = 345;
dr["Size"] = "Hello";
dr["Qty"] = 1;
tblproduct.Rows.Add(dr);
Run Code Online (Sandbox Code Playgroud)
您可以使用DataRow类的ItemArray属性创建一个新行,并传入一个值数组.对于其AutoIncrement设置为true的列,这是一个潜在的问题,因为它的值是自动生成的.要使用ItemArray属性,请将null放在数组中列的位置.
将代码更改为类似的内容
tblproduct.Rows.Add(null,3, 345, "Hello", 1);
tblproduct.Rows.Add(null,5, 3455, "Hecfghhgdfllo", 8);
Run Code Online (Sandbox Code Playgroud)