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

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 C#算法问题, 不知道怎么处理这个数据的转换
  • ¥15 YoloV5 第三方库的版本对照问题
  • ¥15 请完成下列相关问题!
  • ¥15 drone 推送镜像时候 purge: true 推送完毕后没有删除对应的镜像,手动拷贝到服务器执行结果正确在样才能让指令自动执行成功删除对应镜像,如何解决?
  • ¥15 求daily translation(DT)偏差订正方法的代码
  • ¥15 js调用html页面需要隐藏某个按钮
  • ¥15 ads仿真结果在圆图上是怎么读数的
  • ¥20 Cotex M3的调试和程序执行方式是什么样的?
  • ¥20 java项目连接sqlserver时报ssl相关错误
  • ¥15 一道python难题3