一只小菜鸟-_- 2023-05-26 16:59 采纳率: 33.3%
浏览 79
已结题

关于#MFC#数据库工程#的问题,如何解决?

这是用VS2019 MFC写的一个MySQL数据库程序,C++语言写的
在这个函数中,实现教师开设课程操作,代码如下,但是无论开设什么都是失败,请问该如何改?
代码:

void TCHON::OnBnClickedButtonKaishe()
{
    // TODO: 在此添加控件通知处理程序代码
    USES_CONVERSION;
    kehao.GetWindowTextW(strkehao);
    keming.GetWindowTextW(strkeming);
    xuefen.GetWindowTextW(strxuefen);
    //if(!strkehao)MessageBox(TEXT("开设课程失败!"));
    double flxuefen = atof(T2A(strxuefen.GetBuffer(0)));
    CString query;
    query.Format(_T("开设课程('%s','%s',%f,'%s');"), strkehao,strkeming,flxuefen,strnum);
    char* charquery = T2A(query.GetBuffer(0));
    query.ReleaseBuffer();
    if (mysql_query(&m_sqlCon, charquery))//如果函数执行成功则返回0,不成功就进入if语句
    {
        CString error; 
        error = mysql_sqlstate(&m_sqlCon);
        if (error == "09000")
        {
            CString errormsg;
            errormsg = mysql_error(&m_sqlCon);
            MessageBox(errormsg);
        }
        else
        MessageBox(TEXT("开设课程失败!"));
        return;
    }

    query.Format(_T("select * from 课程 where 课号 in (select 课号 from 教授 natural join 教师 where 教师编号=%s);"), strnum);
    charquery = T2A(query.GetBuffer(0));
    query.ReleaseBuffer();
    mysql_query(&m_sqlCon, charquery);
    MYSQL_RES* m_res = mysql_store_result(&m_sqlCon);
    if (mysql_num_rows(m_res) != 0)
    {
        UpdateList(m_res);
    }
    else MessageBox(L"未开设课程!");
}


失败截图:

img

表的结构:

img

img

  • 写回答

4条回答 默认 最新

  • 急速光粒 2023-05-27 22:14
    关注

    看情况应该是你的sql有问题,建议先在数据库中执行无误后,再放入代码调试。

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

报告相同问题?

问题事件

  • 系统已结题 6月5日
  • 已采纳回答 5月28日
  • 修改了问题 5月26日
  • 创建了问题 5月26日

悬赏问题

  • ¥35 MIMO天线稀疏阵列排布问题
  • ¥60 用visual studio编写程序,利用间接平差求解水准网
  • ¥15 Llama如何调用shell或者Python
  • ¥20 谁能帮我挨个解读这个php语言编的代码什么意思?
  • ¥15 win10权限管理,限制普通用户使用删除功能
  • ¥15 minnio内存占用过大,内存没被回收(Windows环境)
  • ¥65 抖音咸鱼付款链接转码支付宝
  • ¥15 ubuntu22.04上安装ursim-3.15.8.106339遇到的问题
  • ¥15 blast算法(相关搜索:数据库)
  • ¥15 请问有人会紧聚焦相关的matlab知识嘛?