注册
 找回密码
 注册
江西广告网
查看: 258|回复: 0
打印 上一主题 下一主题

为 DataGrid 中的行增加序号

[复制链接]

该用户从未签到

1
跳转到指定楼层
发表于 2008-12-24 11:59:37 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?注册

x
  有时,你需要为在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。       <
您需要登录后才可以回帖 登录 | 注册

本版积分规则

快速回复 返回顶部 返回列表