Qt Sqlite数据库(sql语句操作)

使用Qt的数据库之前,首先要在项目文件里加入如图的sql字段


image.png

通过下列代码可打印出本机所支持的所有数据库引擎

//打印Qt支持的数据库引擎
    qDebug()<

我的机器输出如下,

("QSQLITE", "QMYSQL", "QMYSQL3", "QODBC", "QODBC3", "QPSQL", "QPSQL7")

添加数据库

下列代码添加一个Sqlite数据库引擎

    QSqlDatabase db=QSqlDatabase::addDatabase("QSQLITE");

设置数据库

//设置数据库
    db.setDatabaseName("../info.db");

打开数据库

如果下列语句能够正常执行通过而不直接return终止,那么后面能执行的代码就是打开成功的代码

//打开数据库
    if(!db.open()){
        //如果数据库打开失败
        QMessageBox::warning(this,"错误",db.lastError().text());
        return;
    }

数据库插入

只要前面的数据库创建成功,后面直接创建对象

QSqlQuery query;

就可以执行任意sql语句
query.exec(sql语句字符串)

简单的sql语句讲解

以下sql语句均可以直接在SQLiteBrowser可视化浏览器中直接执行

创建数据库表

create table student(id int primary key, name varchar(255), age int, score int);

上述sql语句创建了一张表,
表名为student
其中有id:int数字作为键
有字段name:varchar(255)
age:int
score:int
在一个数据表中,每一条数据都拥有一个唯一的主键,在创建数据表时,primary key用于标识每一条数据的主键,上述创建的数据表中id作为int类型的主键

删除数据库表

drop table student

上述sql语句将删除一个数据库表

插入数据

insert into student (id, name, age) values(1,"mike",18);
insert into student (id, name, age, score) values(2,"lucy",22,90);
insert into student (id, name, age, score) values(3,"Tom",20,78);

上述操作将像student数据表中增加三个数据库条目,注意第一个参数id为数据库的主键,每条数据的主键不能重复,否则数据库将会报错重复添加。
执行上述sql语句后,通过SQLiteBrowser可查看出数据库student表中将存在如下信息,


image.png

更新数据

update student set score = 90 where id =3

更新student数据表中,从id=3的条目中,设置score=90
即修改student表中id=3的数据项的score为90

查找数据

select * from student
image.png

如上代码,为选中student数据表中所有键的数据


select name from student

这条sql语句用于选中student数据表中的所有name键的数据

image.png


select score from student where name="Tom"

这条sql语句用于选中student数据表中name="Tom"的score

删除数据

delete from student where name = "mike"

这条sql语句用于删除所有student数据表中name=“mike”的表项

插入单条数据

image.png

如下代码,当Insert按钮按下,直接执行下列代码,

    QString id=ui->idBox->text();
    QString name=ui->nameEdit->text();
    QString age=ui->ageBox->text();
    QString score=ui->scoreBox->text();
    QSqlQuery query;

    QString insertSql="insert into student(id,name,age,score) values(%1,'%2',%3,%4)";
    insertSql=insertSql.arg(id,name,age,score);
    query.exec(insertSql);

则可以插入一条数据

批量插入数据

//Windows的ODBC风格操作数据库
    //创建sql预处理语句?为占位符,后面将根据数据编译为普通sql语句

    query.prepare("insert into student(id,name,age,score) values(?,?,?,?)");

    //分别创建几个键的列表
    QVariantList idList,nameList,ageList,scoreList;
    idList<<1<<2<<3;
    nameList<<"A"<<"B"<<"C";
    ageList<<11<<22<<33;
    scoreList<<59<<69<<79;

    //按顺序绑定相应的值
    query.addBindValue(idList);
    query.addBindValue(nameList);
    query.addBindValue(ageList);
    query.addBindValue(scoreList);

    //执行预处理命令
    query.execBatch();

以上代码将批量添加三个数据项,如图


image.png

实际上底层为分别构造并执行了3条sql语句。


 //Oracle风格

    //与odbc风格不同的是,oracle风格的占位为 :+自定义名称(一般和键名称相同)
    query.prepare("insert into student(id,name,age,score) values(:id,:name,:age,:score)");

    //分别创建几个键的列表
    QVariantList idList,nameList,ageList,scoreList;
    idList<<1<<2<<3;
    nameList<<"A"<<"B"<<"C";
    ageList<<11<<22<<33;
    scoreList<<59<<69<<79;

    //按字段绑定
    query.bindValue(":id",idList);
    query.bindValue(":name",nameList);
    query.bindValue(":age",ageList);
    query.bindValue(":score",scoreList);

    //执行预处理命令
    query.execBatch();
image.png

由上可看出,两者区别除了占位符不同外,仅在于前者的addBindValue有序,后者的bindValue可以无序

遍历数据库

    QSqlQuery query;
    query.exec("select * from student");


    QString result="";
    //遍历取得的所有结果
    while(query.next()){
        result+=query.value(0).toString()+' ';
        result+=query.value("name").toString()+' ';
        result+=query.value(2).toString()+' ';
        result+=query.value("score").toString()+' ';
        result+='\n';
    }
    QMessageBox::information(this,"查询结果",result);

如上代码,指定query.next()则依次从第0条数据项遍历到最后一项,其中通过query.value(整数)可以按照索引获取相应键的值,同样也可以直接传入键名获取对应的值。

查询数据项

设计界面如图,


image.png

代码如下,

QSqlQuery query;
    query.exec(QString("select * from student where %1 = %2")
               .arg(ui->keyBox->currentText(),
                    ui->findValueEdit->text()));


    QString result="";
    //遍历取得的所有结果
    while(query.next()){
        result+=query.value("id").toString()+' ';
        result+=query.value("name").toString()+' ';
        result+=query.value("age").toString()+' ';
        result+=query.value("score").toString()+' ';
        result+='\n';
    }
    if(result.isEmpty()){
        QMessageBox::warning(this,"查询结果","找不到结果");
    }else{
        QMessageBox::information(this,"查询结果",result);
    }

可实现数据库的查询。
如数据库中添加两个重名的张三,点击这个查询数据,将可查询出所有的张三.


image.png

删除数据项

只需要将上述查询数据项的sql语句中的select *替换为delete即可,代码如下

    QSqlQuery query;
    bool success=query.exec(QString("delete from student where %1 = %2")
               .arg(ui->keyBox->currentText(),
                    ui->findValueEdit->text()));
    if(success){
        QMessageBox::information(this,"删除成功","删除成功");
    }

你可能感兴趣的:(Qt Sqlite数据库(sql语句操作))