VB 关于recordset的一个很简单的的问题
1的前一个不死0吗?怎么会是-2?还有就是执行recordset.movefirst后,为什么VB不会立即报错?因为我的理解是:只要recordset.AbsoluteP...
1的前一个不死0吗?怎么会是-2?还有就是执行 recordset.movefirst后,为什么VB不会立即报错?因为我的理解是:只要recordset.AbsolutePosition超出1,就应该报错我的理解错在哪了?
展开
1个回答
展开全部
Absolute意思是绝对,Position的含义是位置
rs.AbsolutePosition返回当前记录的绝对位置
rs.MoveFirst对应的rs.AbsolutePosition 为1
在这样的状态,执行rs.MovePrevious,那么记录指针就前移到了数据表的外部,这个时候记录指针并没有指向任何一条记录,这里返回-2仅仅是系统规定的一个值,它就表示记录指针是从数据表内前移到数据表外部的。
类似的道理,执行:
rs.MoveLast
rs.MoveNext
rs.AbsolutePosition为-3
这里也是系统规定的值,用来表示记录指针是从数据表内后移到数据表外部的。
只要返回的记录集合有记录存在,无论是执行:MoveFirst还是MoveLast系统都不会报错!
但是,系统提供了Eof和Bof属性,用来获得记录指针是否移动到数据表外部的信息。
1,当记录指针指向数据表内任何一条记录的时候,,rs.Eof和rs.Bof属性都为False值。
2,当记录指针前移到数据表外部的时候,,rs.Eof属性值为False,rs.Bof属性值为true。
3,当记录指针后移到数据表外部的时候,,rs.Eof属性值为true,rs.Bof属性值为False。
比如你可以通过实验来观察:
1)
rs.MoveFirst
msgbox rs.Eof & " " & rs.Bof
2)
rs.MoveLast
msgbox rs.Eof & " " & rs.Bof
3)
rs.MoveFirst
rs.MovePrevious
msgbox rs.Eof & " " & rs.Bof
4)
rs.MoveLast
rs.MoveNext
msgbox rs.Eof & " " & rs.Bof
rs.AbsolutePosition返回当前记录的绝对位置
rs.MoveFirst对应的rs.AbsolutePosition 为1
在这样的状态,执行rs.MovePrevious,那么记录指针就前移到了数据表的外部,这个时候记录指针并没有指向任何一条记录,这里返回-2仅仅是系统规定的一个值,它就表示记录指针是从数据表内前移到数据表外部的。
类似的道理,执行:
rs.MoveLast
rs.MoveNext
rs.AbsolutePosition为-3
这里也是系统规定的值,用来表示记录指针是从数据表内后移到数据表外部的。
只要返回的记录集合有记录存在,无论是执行:MoveFirst还是MoveLast系统都不会报错!
但是,系统提供了Eof和Bof属性,用来获得记录指针是否移动到数据表外部的信息。
1,当记录指针指向数据表内任何一条记录的时候,,rs.Eof和rs.Bof属性都为False值。
2,当记录指针前移到数据表外部的时候,,rs.Eof属性值为False,rs.Bof属性值为true。
3,当记录指针后移到数据表外部的时候,,rs.Eof属性值为true,rs.Bof属性值为False。
比如你可以通过实验来观察:
1)
rs.MoveFirst
msgbox rs.Eof & " " & rs.Bof
2)
rs.MoveLast
msgbox rs.Eof & " " & rs.Bof
3)
rs.MoveFirst
rs.MovePrevious
msgbox rs.Eof & " " & rs.Bof
4)
rs.MoveLast
rs.MoveNext
msgbox rs.Eof & " " & rs.Bof
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询