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

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


image.png

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

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

我的机器输出如下,

("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,"删除成功","删除成功");
    }
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,293评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,604评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,958评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,729评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,719评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,630评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,000评论 3 397
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,665评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,909评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,646评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,726评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,400评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,986评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,959评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,197评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,996评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,481评论 2 342