急 问Access数据库资源释放的问题 真心求教

xueshi 2006-01-17 03:01:56
虽然发的帖子不太是地方

这里人气旺

就是 我调用方法 弹出对话框 同时列出数据库的一些内容

但是我关闭对话框 再打开 就抛出异常了

是不是 数据库资源没有释放的问题啊?

代码如下:

BOOL CDlgDetail::OnInitDialog()
{
CDialog::OnInitDialog();

// 初始化COM,创建ADO连接等操作
AfxOleInit();
HRESULT hr;
try{
hr = m_pConnection.CreateInstance("ADODB.Connection");///创建Connection对象
if(SUCCEEDED(hr))
{
hr = m_pConnection->Open("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=db1.mdb","","",adModeUnknown);
///连接数据库

}
}
catch(_com_error e)///捕捉异常
{
CString errormessage;
errormessage.Format("连接数据库失败!\r\n 错误信息:%s",e.ErrorMessage());
AfxMessageBox(errormessage);//显示错误信息
}

UpdateData();

m_pRecordset.CreateInstance(__uuidof(Recordset));
try
{
m_pRecordset->Open("select * from liang ", // 查询DemoTable表中所有字段
m_pConnection.GetInterfacePtr(), // 获取库接库的IDispatch指针
adOpenDynamic,
adLockOptimistic,
adCmdText);

}
catch(_com_error *e)
{
AfxMessageBox(e->ErrorMessage());
}

while(!m_pRecordset->adoEOF)
{
_variant_t time;
_variant_t movie;


time = m_pRecordset->GetCollect ("time");
movie = m_pRecordset->GetCollect ("movie");

CString s_time =(char *)_bstr_t(time);
CString s_movie =(char *)_bstr_t(movie);

s_time.TrimRight();
s_movie.TrimRight();

m_lst.AddString(s_time);
m_lst.AddString(s_movie);
m_pRecordset->MoveNext();
}


return TRUE; // return TRUE unless you set the focus to a control
// EXCEPTION: OCX Property Pages should return FALSE
}

void CDlgDetail::OnClose()
{
// m_pRecordset->Close();///关闭记录集 ,执行到这句抛出异常 需要注释掉
m_pConnection->Close();///关闭连
CDialog::OnClose();
}

我想每次打开对话框 就调用数据库

下次打开不抛出异常

请问 我是不是资源没有释放对啊

真心求教
...全文
202 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
xueshi 2006-01-17
  • 打赏
  • 举报
回复
呵呵 是啊

release 有点错误

结贴了 下次不会犯这种错误了
xueshi 2006-01-17
  • 打赏
  • 举报
回复
呵呵 谢谢大家 是因为没有放到

BOOL CXXXApp::InitInstance()里
handsomerun 2006-01-17
  • 打赏
  • 举报
回复
昏,搞错了
不用release

if(m_pRecordset->State)
{
m_pRecordset->Close();

}

m_pRecordset= NULL;

if(m_pConnection->State)
{
m_pConnection->Close();

}
m_pConnection= NULL;

你把AfxOleInit
放到app的InitInstance里吧
handsomerun 2006-01-17
  • 打赏
  • 举报
回复
判断了吗??
if(m_pRecordset->State)
{
m_pRecordset->Close();

}
m_pRecordset ->Release()
m_pRecordset = NULL

if(m_pConnection->State)
{
m_pConnection->Close();
}

m_pConnection->Release()
m_pConnection = NULL

这样试试
thisisll 2006-01-17
  • 打赏
  • 举报
回复
BOOL CXXXApp::InitInstance()里
HelloIvan2005 2006-01-17
  • 打赏
  • 举报
回复
mark, study
thisisll 2006-01-17
  • 打赏
  • 举报
回复
// 初始化COM,创建ADO连接等操作
AfxOleInit();
这个放到你的APP初始化里

16,551

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Creator Browser
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧