小议ADO.NET中的自动增量列

发表于:2007-05-25来源:作者:点击数: 标签:增量ADO.NET小议自动中的
ADO.NET中通过DataColumn的3个属性来支持自动增量列:AutoIncrement,AutoIncrementSeed,AutoIncrementStep。只要将DataColumn的AutoIncrement设置为True即可以为DataTable的新行生成自动增量值。看个例子: DataSetds = new Dataset(); DataTabledt = ds.Ta

   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。

 

原文转自:http://www.ltesting.net