设为首页收藏本站Access中国

Office中国论坛/Access中国论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

返回列表 发新帖
查看: 3865|回复: 4
打印 上一主题 下一主题

[ADO/DAO] 关于.MoveNext的一点疑惑

[复制链接]
跳转到指定楼层
1#
发表于 2015-9-27 11:57:54 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式


用下面的代码将表中的NULL值可以全部替换为0, 不过不理解为何要用LOOP?
个人理解,.MoveNext作用就是移动到下一条记录。(但是不加LOOP,只会对第一行起作用)


请高人指点下,非常感谢!



原帖链接:
http://www.office-cn.net/forum.p ... mp;page=1#pid732029

代码:
Sub test()
Dim res As ADODB.Recordset
Dim i   As Integer
Set res = New ADODB.Recordset
res.Open "Data", CurrentProject.Connection, adOpenDynamic, adLockOptimistic
res.MoveFirst
Do While Not res.EOF
With res
For i = 1 To 10
   If IsNull(.Fields(i & "月")) Then
      .Fields(i & "月") = 0
   End If
Next i
.MoveNext
End With
Loop
End Sub
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 分享淘帖 订阅订阅
2#
发表于 2015-9-29 17:16:41 | 只看该作者
怎么说呢?
其实像这个,应该加上update的。
加上loop只代表光标移动到下一行。
假定没有loop,那么就是修改了第一行,并将光标移动到下一行,仅此而已。当然不会对全部记录进行修改了。

3#
 楼主| 发表于 2015-10-4 19:53:37 | 只看该作者
roych 发表于 2015-9-29 17:16
怎么说呢?
其实像这个,应该加上update的。
加上loop只代表光标移动到下一行。

谢谢版主指点,明白了。

我的理解是:MOVENEXT每次调用就会下移动一行,类似于放了个指针。LOOP就是负责调用它的。


非常感谢!
4#
发表于 2015-12-13 21:11:34 | 只看该作者
不错了学习学习

点击这里给我发消息

5#
发表于 2019-2-12 16:22:17 | 只看该作者
不错学习
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|站长邮箱|小黑屋|手机版|Office中国/Access中国 ( 粤ICP备10043721号-1 )  

GMT+8, 2024-5-2 07:07 , Processed in 0.096041 second(s), 28 queries .

Powered by Discuz! X3.3

© 2001-2017 Comsenz Inc.

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