Qt Qsqlite
sqlite是本地的静态数据库,其使用方法和前面学的sql非常的相似,这里仅仅使用构造函数就可以实现对sqlite数据库内容的输入和遍历,首先在工程目录的上一级创建一个后缀名为.db的数据库文件,这里命名为info.db。
工程目录:
mywidget.cpp:
#include "mywidget.h" #include "ui_mywidget.h" #include <QSqlDatabase> #include <QDebug> #include <QMessageBox> #include <QSqlError> #include <QSqlQuery>//专门对SQL语句操作的类 #include <QVariantList> #include <QString> MyWidget::MyWidget(QWidget *parent) : QWidget(parent), ui(new Ui::MyWidget) { ui->setupUi(this); //打印Qt支持的数据库驱动 qDebug()<<QSqlDatabase::drivers(); //添加Sqlite数据库 QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE"); //设置数据库 db.setDatabaseName("../info.db"); //打开数据库 只有打开数据库才能进行下面的操作: 增 删 改 查 if(db.open() == false) { QMessageBox::warning(this,"错误",db.lastError().text()); return; } QSqlQuery query;//(id ,name, age,score) query.exec("create table student (id int primary key ,name varchar(255) ,age int ,score int )"); // query.exec("insert into student values(1,'mike1',18,59)"); // query.exec("insert into student values(2,'mike2',18,59)"); // query.exec("insert into student values(3,'mike3',18,59)"); query.prepare("insert into student(name, age,score) values (?,?,? );"); //给字段设置内容 list QVariantList nameList; nameList <<"xiaoming "<<"xiaohong"<<"xiaojiang"; QVariantList ageList; ageList <<11<<22<<33; QVariantList scoreList; scoreList<<59<<69<<79; //给字段绑定相应的值 按顺序绑定(否则会出错) query.addBindValue(nameList); query.addBindValue(ageList); query.addBindValue(scoreList); //执行预处理命令 query.execBatch(); query.exec("select * from student "); while(query.next())//一行一行的遍历 { //取出当前行的内容 qDebug()<<query.value(0).toInt() <<query.value(1).toString() <<query.value("age").toInt() <<query.value("score").toInt(); } } MyWidget::~MyWidget() { delete ui; }