VB 中实时错误'3021',BOF或EOF中有一个是"真",或者当前的记录以被删除,所需的操作要求一个当前的记录

Ifcn.State=adStateOpenThencn.CloseDimmyvalAsStringIfCheck1.Value=TrueThenx="单人间"ElseI... If cn.State = adStateOpen Then cn.Close
Dim myval As String
If Check1.Value = True Then
x = "单人间"
ElseIf Check2.Value = True Then
x = "豪华套房"
ElseIf Check3.Value = True Then
x = "总统套房"
End If

cn.Open "driver=microsoft access driver (*.mdb);dbq=" & App.Path & "\dmjd.mdb"
rs.CursorLocation = adUseClient
Dim strtemp
strtemp = "select * from 房间信息表 where style='" & x & "' and 预订= false"
rs.Open strtemp, cn, adOpenDynamic, adLockOptimistic

Y = Val(Text3.Text)
For i = 1 To Y
rs.Fields("预订") = True
rs.MoveNext
Next i
If rs.EOF Then rs.MoveLast
rs.Update

myval = MsgBox("预定" & x & Text3.Text & "间", vbYesNo)
If myval = vbYes Then
Unload frmroom
frmpr.Show
End If
每次运行rs.Fields("预订") = True
都会报错。请问怎么回事?
x是空值,怎么办?
展开
 我来答
damyzl
2011-12-13 · TA获得超过1586个赞
知道大有可为答主
回答量:1475
采纳率:74%
帮助的人:930万
展开全部
你的代码没有处理这种情况:预定数量超过可预定房间数。
rs.Open strtemp, cn, adOpenDynamic, adLockOptimistic
if rs.EOF then exit sub'全部客满,无法预定,退出
'判断可预定房间是否足够
if rs.RecordCount<Y then'房间不足
'询问是否预定剩余的房间
If MsgBox("房间不足,可预定房间有:" & rs.recordcount & vbCrLf & "是否预定这些房间?", vbQuestion + vbDefaultButton2 + vbYesNo, "") = vbNo Then Exit Sub
'如果选择继续预定
Y=rs.RecordCount
end if
'继续原先的代码
For i = 1 To Y
rs.Fields("预订") = True
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
牛人影视
2011-12-13 · TA获得超过1395个赞
知道大有可为答主
回答量:1491
采纳率:0%
帮助的人:1642万
展开全部
For i = 1 To Y
rs.Fields("预订") = True

上面加一句试试:
rs.movefirst
For i = 1 To Y
rs.Fields("预订") = True
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
A_Noodles
2011-12-16
知道答主
回答量:5
采纳率:0%
帮助的人:3.8万
展开全部
QQ联系
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
zx001z7d53
2011-12-13 · TA获得超过2万个赞
知道大有可为答主
回答量:2.4万
采纳率:52%
帮助的人:6010万
展开全部
数据库里加一个自动递增的ID字段就没这毛病了
因为有相同记录,系统糊涂了,不知道你要删除啥
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
吉利吴
2011-12-13 · TA获得超过220个赞
知道小有建树答主
回答量:415
采纳率:0%
帮助的人:220万
展开全部
有人回答过了,你的rs不能为空,另外,你的rs是可以修改的,不是只读的
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 3条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式