当前位置:   article > 正文

qt学习:QTSQL+连接sqlite数据库+增删改查

qt学习:QTSQL+连接sqlite数据库+增删改查

目录

基础

头文件

模块

 编程步骤

实战

ui界面

ui界面的成员定义

构造函数初始化准备

在ui界面类析构函数里关闭数据库

添加按钮

删除按钮

改按钮

查询按钮

效果


基础

现在常用的是sqlite是sqlite 3,我用的是sqlite 3

数据库文件是以db结尾的

查看数据库文件软件下载路径

SQLite administration | SQLite Experticon-default.png?t=N7T8https://www.sqliteexpert.com/download.html

头文件

#include <QTSql>

模块

QT  += core gui sql

 编程步骤

  • 连接数据库,并且要指定要连接哪一个数据库
  • 打开数据库文件,如果文件不存在,则创建
  • 创建表
  • 增删改查

实战

ui界面

ui界面的成员定义

  1. #include <QSqlDatabase>
  2. #include <QSqlError>
  3. #include <QSqlQuery>
  4. #include <QDebug>
  5. private:
  6. QSqlDatabase db;//数据库文件

构造函数初始化准备

  1. //1、连接数据库,指定你要操作的数据库的类型 并且设置数据库文件的名字
  2. //第二个参数不写,指的是该数据库文件 是这个工程默认操作的数据库文件
  3. db = QSqlDatabase::addDatabase("QSQLITE","a1"); //第二个参数指的是连接名称,其实就是标识符
  4. //指定操控的数据库文件,没有则创建,如果用db.open打开文件要密码
  5. db.setDatabaseName("company.db");
  6. //2、打开数据库文件
  7. if(db.open()==false)
  8. {
  9. //db.lastError()错误的原因
  10. qDebug()<<"open error:"<<db.lastError().text();
  11. }
  12. //3、创建表
  13. QString sql = QString("create table if not exists staff(id int unique PRIMARY KEY NOT NULL,name text NOT NULL,address text NOT NULL,salary double NOT NULL);");
  14. //创建一个可以对db执行语句的对象
  15. QSqlQuery query(db);
  16. //执行sql语句
  17. bool ret = query.exec(sql);
  18. if(ret == false)
  19. {
  20. qDebug()<<"create table error "<<query.lastError().text();
  21. }

在ui界面类析构函数里关闭数据库

  1. //关闭数据库
  2. db.close();

添加按钮

  1. //1、获取控件的数据
  2. int id = ui->lineEdit_id->text().toInt();
  3. QString name = ui->lineEdit_name->text();
  4. QString address = ui->lineEdit_address->text();
  5. double salary = ui->lineEdit_salary->text().toDouble();
  6. //2、准备添加sql语句
  7. QString sql = QString("insert into staff values(%1,'%2','%3',%4);").arg(id).arg(name).arg(address).arg(salary);
  8. //创建一个可以对db执行语句的对象
  9. QSqlQuery query(db);
  10. //执行sql语句
  11. bool ret = query.exec(sql);
  12. if(ret == false)
  13. {
  14. qDebug()<<"insert into error "<<query.lastError().text();
  15. }

删除按钮

  1. //以ID作为唯一的标识 ,删除ID所在行的那一条记录
  2. int id = ui->lineEdit_id->text().toInt();
  3. //删除语句
  4. QString sql = QString("delete from staff where id=%1;").arg(id);
  5. //创建一个可以对db执行语句的对象
  6. QSqlQuery query(db);
  7. //执行sql语句
  8. bool ret = query.exec(sql);
  9. if(ret == false)
  10. {
  11. qDebug()<<"delete error "<<query.lastError().text();
  12. }

改按钮

  1. //以ID作为唯一的标识 ,更新其他的数据
  2. int id = ui->lineEdit_id->text().toInt();
  3. QString updateName = ui->lineEdit_name->text();
  4. QString updateAddress = ui->lineEdit_address->text();
  5. double salary = ui->lineEdit_salary->text().toDouble();
  6. //组合更新sql语句
  7. QString sql = QString("update staff set name='%1',address='%2',salary=%3 where id=%4;")
  8. .arg(updateName)
  9. .arg(updateAddress)
  10. .arg(salary)
  11. .arg(id);
  12. //创建一个可以对db执行语句的对象
  13. QSqlQuery query(db);
  14. //执行sql语句
  15. bool ret = query.exec(sql);
  16. if(ret == false)
  17. {
  18. qDebug()<<"update error "<<query.lastError().text();
  19. }

查询按钮

  1. //根据名字查询
  2. QString sql = QString("select * from staff where name=\"%1\";").arg(ui->lineEdit_name->text());
  3. //创建一个可以对db执行语句的对象
  4. QSqlQuery query(db);
  5. //执行sql语句
  6. bool ret = query.exec(sql);
  7. if(ret == false)
  8. {
  9. qDebug()<<"select error "<<query.lastError().text();
  10. }
  11. //查询的结果
  12. //行坐标向下移
  13. while(query.next())
  14. {
  15. //获取数据库query所指的那行的数据
  16. int id = query.value(0).toInt();
  17. QString name = query.value("name").toString();
  18. QString address = query.value("address").toString();
  19. double salary = query.value("salary").toDouble();
  20. //组合字符串
  21. QString text = QString("id:%1 name:%2 address:%3 salary:%4").arg(id).arg(name).arg(address).arg(salary);
  22. //打印
  23. qDebug()<<text;
  24. }

效果

声明:本文内容由网友自发贡献,转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号