上海古都建筑设计集团,上海办公室装修设计公司,上海装修公司高质量的内容分享社区,上海装修公司我们不是内容生产者,我们只是上海办公室装修设计公司内容的搬运工平台

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

guduadmin251月前

目录

基础

头文件

模块

 编程步骤

实战

ui界面

ui界面的成员定义

构造函数初始化准备

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

添加按钮

删除按钮

改按钮

查询按钮

效果


基础

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

数据库文件是以db结尾的

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

SQLite administration | SQLite Expertqt学习:QTSQL+连接sqlite数据库+增删改查,icon-default.png?t=N7T8,第1张https://www.sqliteexpert.com/download.html

头文件

#include

模块

QT  += core gui sql

 编程步骤

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

    实战

    ui界面

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

    ui界面的成员定义

    #include 
    #include 
    #include 
    #include 
    private:
        QSqlDatabase db;//数据库文件

    构造函数初始化准备

        //1、连接数据库,指定你要操作的数据库的类型  并且设置数据库文件的名字
        //第二个参数不写,指的是该数据库文件 是这个工程默认操作的数据库文件
        db = QSqlDatabase::addDatabase("QSQLITE","a1"); //第二个参数指的是连接名称,其实就是标识符
        //指定操控的数据库文件,没有则创建,如果用db.open打开文件要密码
        db.setDatabaseName("company.db");
        
        //2、打开数据库文件
        if(db.open()==false)
        {
            //db.lastError()错误的原因
            qDebug()<<"open error:"< 
    

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

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

    添加按钮

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

    删除按钮

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

    改按钮

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

    查询按钮

        //根据名字查询
        QString sql = QString("select * from staff where name=\"%1\";").arg(ui->lineEdit_name->text());
        //创建一个可以对db执行语句的对象
        QSqlQuery query(db);
        //执行sql语句
        bool ret = query.exec(sql);
        if(ret == false)
        {
            qDebug()<<"select error "< 
    

    效果

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

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

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

网友评论

搜索
最新文章
热门文章
热门标签
 
 怀男孩最早期的微妙感觉  梦见捕鱼 有很多鱼  女人梦见被蛇咬伤手