天宇创梦 2019-07-24 09:55 采纳率: 75%
浏览 388
已采纳

mfc项目,使用mysql查询时有几率造成程序闪退

我用mfc写的基于对话在框项目,其中有一个1秒一次的mysql查询线程,用于程序在线的心跳检测。但是有几率在mysql查询那句时候程序就闪退,代码如下
线程中执行查询:

mysql_select(m_sqlheartCon, "select `xx` from `xx` where `xx`='" + str1 + "' and `upsd`='" + str2 + "';");

查询函数实现,就是传入m_sqlheartCon 对象,str为查询语句,然后返回字段值,具体如下:

//mysql查询
CString mysql_select(MYSQL mysql_Con, CString str)
{
    CString re = "";
    MYSQL_RES *result = NULL;
    MYSQL_ROW sqlrow = NULL;
    DWORD flags;//上网方式 
    if (IsNetworkAlive(&flags) == TRUE)
        {
            if (&mysql_Con != NULL)
            {
                if (mysql_query(&mysql_Con, str)== 0)
                {
                    result = mysql_store_result(&mysql_Con);//保存查询到的数据到result
                    if (result)
                    {
                        if (mysql_num_rows(result) > 0)
                        {
                            sqlrow = mysql_fetch_row(result);
                            if (sqlrow != NULL)
                            {
                                re.Format("%s", sqlrow[0]);
                            }
                        }
                    }
                }
            }
            if (result != NULL) mysql_free_result(result);//释放结果资源
        }
    return re;
}

如果出错就在if (mysql_query(&mysql_Con, str)== 0) 这句这里提示异常,我也分析不出来是为啥异常,有大佬能指导一下什么情况下mysql的查询会出现异常?

  • 写回答

4条回答 默认 最新

  • threenewbee 2019-07-24 10:22
    关注

    可能是数据库服务器连接不稳定,可以用 TRY CATCH宏包裹这个出错的代码,遇到错误跳过去,让程序继续运行。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

悬赏问题

  • ¥15 关于#python#的问题:求帮写python代码
  • ¥20 MATLAB画图图形出现上下震荡的线条
  • ¥15 LiBeAs的带隙等于0.997eV,计算阴离子的N和P
  • ¥15 关于#windows#的问题:怎么用WIN 11系统的电脑 克隆WIN NT3.51-4.0系统的硬盘
  • ¥15 来真人,不要ai!matlab有关常微分方程的问题求解决,
  • ¥15 perl MISA分析p3_in脚本出错
  • ¥15 k8s部署jupyterlab,jupyterlab保存不了文件
  • ¥15 ubuntu虚拟机打包apk错误
  • ¥199 rust编程架构设计的方案 有偿
  • ¥15 回答4f系统的像差计算