zoukankan      html  css  js  c++  java
  • QT 操作数据库SQLite实例

    #include "widget.h"
    #include <QApplication>
    #include <QtSql>
    #include <QTextCodec>
    #include <QDebug>
    
    int main(int argc, char *argv[])
    {
        QApplication a(argc, argv);
        QTextCodec::setCodecForTr(QTextCodec::codecForLocale());
        /*QStringList drivers = QSqlDatabase::drivers(); //获取支持的SQL驱动
        for( int i=0; i!=drivers.count(); i++ )
            qDebug() << "driver: " << drivers.at(i);
        */
        QSqlDatabase dbconn=QSqlDatabase::addDatabase("QSQLITE");    //添加数据库驱动
        dbconn.setDatabaseName("mytest.db");  //在工程目录新建一个mytest.db的文件
        if(!dbconn.open())
        {
            qDebug()<<"error";
        }
    
        QSqlQuery query(dbconn);//以下执行相关QSL语句
        //新建student表,id设置为主键,还有一个name项
        query.exec("create table student(id varchar,name varchar)");
        query.exec(QObject::tr("insert into student values(1,'李刚')"));
        query.exec(QObject::tr("insert into student values(2,'苹果')"));
        query.exec(QObject::tr("insert into student values(3,'葡萄')"));
    
        query.prepare("insert into student values(?,?)");
        QVariantList ids;
        ids << 4 << 5 << 6;
        query.addBindValue(ids);
        QVariantList names;
        names << "kevin" << "xiang" << "jie";
        query.addBindValue(names);
    
        if( !query.execBatch() )
            qDebug() << "Error: " << query.lastError();
    
        query.exec("update student set name='xiangjie' where id=5"); //更新
        query.exec("delete from student where id=6"); //删除
    
        //query.exec("select id,name from student where id>=2");
        query.exec("select * from student");
        while(query.next())//query.next()指向查找到的第一条记录,然后每次后移一条记录
        {
            int ele0=query.value(0).toInt();//query.value(0)是id的值,将其转换为int型
            QString ele1=query.value(1).toString();
            qDebug()<< query.at() <<  ele0<<ele1;//输出两个值
        }    
    
        query.seek(3);
        QSqlRecord record = query.record(); //获取当前行记录
        qDebug() << "id: " << record.value("id").toInt() << " name: " << record.value("name").toString();
    
        QSqlField field = record.field(1);  //获取索引字段
        qDebug() << "field name:" << field.name() << " field value:" << field.value().toString();
    
        query.exec(QObject::tr("drop table student")); //删除table
        //return a.exec();
    }
    

  • 相关阅读:
    InnoDB的锁机制浅析(二)—探索InnoDB中的锁(Record锁/Gap锁/Next-key锁/插入意向锁)
    InnoDB的锁机制浅析(一)—基本概念/兼容矩阵
    InnoDB的锁机制浅析(All in One)
    JMS Java消息服务(Java Message Service)
    命名和目录接口 JNDI-The Java Naming and Directory Interface
    Jenkins系列教程之
    Jenkins系列教程之
    Jenkins系列教程之
    【小笔记】大数据量excel解析工具性能对比
    【小笔记】Activiti扩展数据库支持类型
  • 原文地址:https://www.cnblogs.com/xj626852095/p/3648096.html
Copyright © 2011-2022 走看看