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;
}

 

posted @ 2019-07-12 14:34  Mr_Song_D  阅读(1053)  评论(0编辑  收藏  举报