验证码: 看不清楚,换一张 查询 注册会员,免验证
  • {{ basic.site_slogan }}
  • 打开微信扫一扫,
    您还可以在这里找到我们哟

    关注我们

在Qt中怎么操作MySQL数据库

阅读:1134 来源:乙速云 作者:代码code

在Qt中怎么操作MySQL数据库

      一、安装驱动

      (1)安装

      在Qt中操作MySQL数据库首先要安装mysql的驱动文件,将MySQL下的libmusql.dll文件复制到Qt的安装路径下的bin文件夹下即可。

      在Qt中怎么操作MySQL数据库

      直接将libmysql.dll文件粘贴到此文件夹中。

      在Qt中怎么操作MySQL数据库

      (2)验证驱动是否安装成功 

      复制成功之后来测试一下驱动程序是否安装成功,新建一个文件,选择Qt设计师界面类,后面的操作都保持默认即可。

      在Qt中怎么操作MySQL数据库

      在新生成的.cpp文件中引入以下库

      #include 
      #include 
      #include   
      #include     
      #include 
      #include 
      #include 

      在构造函数中插入以下代码,然后点击运行,如果不弹出警告窗口则说明安装成功,否则就是失败了。

      //添加一个数据库
          QSqlDatabase db=QSqlDatabase::addDatabase("QMYSQL");    //括号内要写出数据库的类型
          //设置数据库
          db.setHostName("127.0.0.1"); //设置数据库的主机ip
          //设置数据库的用户名
          db.setUserName("root");
          //设置数据库的密码
          db.setPassword("123456");    //这个就是安装MySQL时设置的密码
          //设置数据库的名字
          db.setDatabaseName("aaa2");
          //打开数据库(已经安装过mysql驱动了)
          if(db.open()==false){
              QMessageBox::warning(this,"waring",db.lastError().text());
          }

      二、使用MySQL数据库

      (1)单语句执行

      首先创建一个QString对象sql,将要执行的语句写在 sql中,然后创建QSqlQuery类的对象query,调用其exec()函数执行sql中的代码。

          QString sql = "insert into student (id,name,age,math) values (1,'kaw',20,97)";	//书写想要执行的语句
          QSqlQuery query;	//创建一个QSqlQuery对象
          query.exec(sql);    //执行mysql语句

      (2)多语句执行

      在sql中,每条语句用分号隔开就可以同时执行多条语句了。下面同时对表格进行增加、删除和更新操作。

          QString sql = "insert into student (id,name,age,math) values (13,'kaw',20,97);delete from student where id=2;update student set name='sdd',math=100 where id=10;";
          QSqlQuery query;	//创建一个QSqlQuery对象
          query.exec(sql);    //执行mysql语句

      (3)批处理操作

      方式一:addBindValue()

      在query.prepare()中输入自己想要执行的语句,其中待输入的值用“?”代替,在这里“?”就是通配符。后面再用idList、nameList、ageList和mathList添加自己想要设置的值。注意,addBindValue()绑定值的顺序需要与id、name、age、math的顺序一致。

          QSqlQuery query;
          query.prepare("insert into student (id,name,age,math) values (?,?,?,?)");	//书写语句模型
          //添加绑定数据
          QVariantList idList;    //创建一个id列表
          idList << 15<<16<<17;
          query.addBindValue(idList); //完成第一个?的绑定
          QVariantList nameList;
          nameList << "ddd"<<"eee"<<"jjj";
          query.addBindValue(nameList);   //完成第二个?的绑定
          QVariantList ageList;
          ageList << 25<<24<<23;
          query.addBindValue(ageList);    //完成第三个?的绑定
          QVariantList mathList;
          mathList << 90<<89<<90;
          query.addBindValue(mathList);   //完成第四个?的绑定
          //执行批处理
          query.execBatch();

      方式二:bindValue()

      直接用自定义的名称来完成绑定,这时绑定顺序可以自己决定。

      	QSqlQuery query;
          query.prepare("insert into student (id,name,age,math) values (:id,:name,:age,:math)");  //:id之类的名字时自定义的 自己方便就好
          //添加绑定数据
          QVariantList idList;    //创建一个id列表
          idList << 18<<19<<20;
          query.bindValue(":id",idList); //完成:id的绑定
          QVariantList nameList;
          nameList << "ddd"<<"eee"<<"jjj";
          query.bindValue(":name",nameList);   //完成:name的绑定
          QVariantList ageList;
          ageList << 25<<24<<23;
          query.bindValue(":age",ageList);    //完成:age的绑定
          QVariantList mathList;
          mathList << 90<<89<<90;
          query.bindValue(":math",mathList);   //完成:math的绑定
          //执行批处理
          query.execBatch();

      (4)查询

      要查询的表为:

      在Qt中怎么操作MySQL数据库

      value后的值可以是索引,也可以是列名。取出后需要将其转为对应的数据类型。

      	//查询操作
          QSqlQuery query;
          query.exec("select * from student");
          while(query.next()){
              qDebug()<

      查询结果:

      在Qt中怎么操作MySQL数据库

    分享到:
    *特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们: hlamps#outlook.com (#换成@)。
    相关文章
    {{ v.title }}
    {{ v.description||(cleanHtml(v.content)).substr(0,100)+'···' }}
    你可能感兴趣
    推荐阅读 更多>