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

 

转载于:https://www.cnblogs.com/doker/p/11175925.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值