.net mysql 序号,为DataGrid中的行增加序号!-.NET教程,数据库应用

有时,你需要为在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。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值