
VC++数据库操作问题
我用VC++做了个程序,连接的是access2003数据库,每条记录有三列,均为文本类型,现在我用m_pRecordset->Delete(adAffectCurrent...
我用VC++做了个程序,连接的是access2003数据库,每条记录有三列,均为文本类型,现在我用
m_pRecordset->Delete(adAffectCurrent);
m_pRecordset->MoveNext();
这两个语句删除一条当前记录,删除后总记录m_total的值需要减1,但是当前记录m_index的值和总记录m_total的值不能协调好,当浏览到最后一条记录时会发生m_index大于m_total的情况,系统报错,请问删除记录后怎么调整变量才能避免这种错误?谢谢 展开
m_pRecordset->Delete(adAffectCurrent);
m_pRecordset->MoveNext();
这两个语句删除一条当前记录,删除后总记录m_total的值需要减1,但是当前记录m_index的值和总记录m_total的值不能协调好,当浏览到最后一条记录时会发生m_index大于m_total的情况,系统报错,请问删除记录后怎么调整变量才能避免这种错误?谢谢 展开
4个回答
展开全部
原因是因为你删除记录之后,m_index又没有更新!程序又显示着被删除的记录!控件又和数据库变量连在一起!应该在删除记录之前将先移动显示的记录!
int i;
if(m_pRecordset.IsEOF())
{
i=m_index-1
m_pRecordset->MovePrev();
}
else
{
i=m_index+1
m_pRecordset->MoveNext();
}
m_pRecordset->Delete(i);
int i;
if(m_pRecordset.IsEOF())
{
i=m_index-1
m_pRecordset->MovePrev();
}
else
{
i=m_index+1
m_pRecordset->MoveNext();
}
m_pRecordset->Delete(i);

2023-08-15 广告
通常情况下,我们会按照结构模型把系统产生的数据分为三种类型:结构化数据、半结构化数据和非结构化数据。结构化数据,即行数据,是存储在数据库里,可以用二维表结构来逻辑表达实现的数据。最常见的就是数字数据和文本数据,它们可以某种标准格式存在于文件...
点击进入详情页
本回答由光点科技提供
展开全部
做一个条件语句,如果删除的记录是最后一条记录,则INdex不再+1否则,你删除的记录是最后。而你的Index还+1就出错了。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
if(!m_pRecordset.IsEOF())
m_total--;
m_total--;
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
if(!m_pRecordset.IsEOF())
m_total--;
m_total--;
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询