学生管理系统中,修改密码点击确定后:连接占线导致另一个hstmt

monkeyfly007 2015-07-08 07:14:53
我在做一个课程设计,学生成绩管理系统可是为什么会出现这个问题?在修改密码界面,点击确定时就弹出这个错误窗口,不知道怎么回事。(是不是没有释放对象还是?问题见代码[User]部分)

void CMyDialog::OnOK() //用户登录界面,确定按钮
{
// TODO: Add extra validation here
CString Username,Password;
m_username.GetWindowText(Username);
m_password.GetWindowText(Password);
if(!m_database.IsOpen())
{
if(m_database.Open(_T("student")))
{
m_recordset.m_pDatabase=&m_database;
CString strSQL;
strSQL.Format("select * from [User] where User_name='%s' and User_password='%s'",Username,Password);
m_recordset.Open(CRecordset::forwardOnly,strSQL);
if(m_recordset.GetRecordCount()==0)
{
MessageBox("用户名或密码错误!","错误!",MB_OK|MB_ICONWARNING);
m_password.SetWindowText("");
m_password.SetFocus();
}
else
{
//m_recordset.GetFieldValue("");
CDialog::OnOK();
}
}
m_recordset.Close();
m_database.Close();
}
else
{
MessageBox("不能打开数据库!");
}
//CDialog::OnOK();
}

void CPasswordDlg::OnOK() //修改密码界面,确定按钮
{
// TODO: Add extra validation here
CString Username,Password,Newpassword,Confirmpassword;
m_username.GetWindowText(Username);
m_password.GetWindowText(Password);
m_new.GetWindowText(Newpassword);
m_confirm.GetWindowText(Confirmpassword);

CDatabase m_database;
CRecordset m_recordset;
if(Newpassword.IsEmpty()||Confirmpassword.IsEmpty())
{
MessageBox("密码不能为空!");
}
else
{
if(Newpassword!=Confirmpassword)
{
MessageBox("两次密码不一致,请重新输入密码");
m_new.SetWindowText("");
m_confirm.SetWindowText("");
m_new.SetFocus();
}
else
{
if(!m_database.IsOpen())
{
if(m_database.Open(_T("student")))
{
m_recordset.m_pDatabase=&m_database;
CString strSQL;
strSQL.Format("select * from [User] where User_name='%s' and User_password='%s'",Username,Password);
m_recordset.Open(CRecordset::forwardOnly,strSQL);
if(m_recordset.GetRecordCount()==0)
{
MessageBox("用户名或密码错误!","错误!",MB_OK|MB_ICONWARNING);
m_password.SetWindowText("");
m_new.SetWindowText("");
m_confirm.SetWindowText("");
m_password.SetFocus();
}
else
{
strSQL.Format("update [User] set User_password='%s' where User_name='%s'",Newpassword,Username);
m_database.ExecuteSQL(strSQL);
MessageBox("修改密码成功");
CDialog::OnOK();
}
m_recordset.Close();
m_database.Close();
}
else
{
MessageBox("不能打开数据库!");
}
}
}
}
}
...全文
136 回复 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
回复
切换为时间正序
请发表友善的回复…
发表回复

22,300

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 疑难问题
社区管理员
  • 疑难问题社区
  • 尘觉
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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