有时,你需要为在DataGrid中显示每行的序号,如果使用Oracle数据库,你可以利用RowNum在Select命令中构造行序号,然后直接绑定到DataGrid,但是如果用的是SQL Server数据库,那么,该如何为Datagrid中增加行序号呢?
ADO.NET 中通过 DataColumn 的3个属性来支持自动增量列: AutoIncrement,AutoIncrementSeed,AutoIncrementStep 。只要将 DataColumn 的 AutoIncrement 设置为 True 即可以为 DataTable 的新行生成自动增量值。看个例子:
DataSet ds= new Dataset();
DataTable dt=ds.Tables.Add("Orders");
DataColumn col=dt.Columns.Add("OrderID", typeof ( int ));
col.AutoIncrement= true ;
col.AutoIncrementSeed=-1;
col.AutoIncrementStep=-1;
col.ReadOnly= true ;
上面 OrderID 列被设为自动增量,注意后面接下来两句,其值都被设为-1 , 其中有一定的原因。 AutoIncrementSeed 和 AutoIncrementStep 控制着如何生成新值。当遇到空表时, ADO.NET 会将存储在 AutoIncrementSeed 中的值赋给第一行自动增量列,接着 AutoIncrementStep 生成后续的自动增量值。
原因: ADO.NET 中生成的自动增量值仅仅是一个占位符,在数据库中会生成真正的新值,显示出来的仅仅是未提交给数据库的新行自动增量值,数据库可能会根据生成的值来生成不同的值。 AutoIncrementSeed 和 AutoIncrementStep 都设为-1,可以确保生成的占位符值不会出现在数据库。
所以在使用 AutoIncrement 的时候应将 AutoIncrementSeed 和 AutoIncrementStep 都设为 -1 。