使用Qt的数据库之前,首先要在项目文件里加入如图的sql字段
通过下列代码可打印出本机所支持的所有数据库引擎
//打印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表中将存在如下信息,
更新数据
update student set score = 90 where id =3
更新student数据表中,从id=3的条目中,设置score=90
即修改student表中id=3的数据项的score为90
查找数据
select * from student
如上代码,为选中student数据表中所有键的数据
select name from student
这条sql语句用于选中student数据表中的所有name键的数据
select score from student where name="Tom"
这条sql语句用于选中student数据表中name="Tom"的score
删除数据
delete from student where name = "mike"
这条sql语句用于删除所有student数据表中name=“mike”的表项
插入单条数据
如下代码,当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();
以上代码将批量添加三个数据项,如图
实际上底层为分别构造并执行了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();
由上可看出,两者区别除了占位符不同外,仅在于前者的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(整数)可以按照索引获取相应键的值,同样也可以直接传入键名获取对应的值。
查询数据项
设计界面如图,
代码如下,
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);
}
可实现数据库的查询。
如数据库中添加两个重名的张三,点击这个查询数据,将可查询出所有的张三.
删除数据项
只需要将上述查询数据项的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,"删除成功","删除成功");
}