首页 > 编程 > .NET > 正文

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

2024-07-21 02:07:54
字体:
来源:转载
供稿:网友

   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。

 
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表