QSqlDatabase数据库

来源:互联网 发布:网络直播行业现状 编辑:程序博客网 时间:2024/05/21 11:12
#include <QSqlDatabase>#include <QtDebug>#include <QSqlQuery>#include <QSqlError>#include <QSqlRecord>//创建数据库QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE", "sqlite1");db.setHostName("acidalia");db.setDatabaseName("customdb");db.setUserName("root");db.setPassword("123456");if( !db.open()){   qDebug() << "db.open failed.";}//创建表db = QSqlDatabase::database("sqlite1"); //建立数据库连接QSqlQuery query(db);bool success = query.exec("create table automobil(id int, name varchar)");if(success){    qDebug() << QObject::tr("create table success.");}else{    qDebug() << QObject::tr("create table failed.");}//插入记录for(int i = 0; i < 10; i++){    query.prepare("INSERT INTO automobil (id, name) "                      "VALUES (:id, :name)");    query.bindValue(":id", i);    query.bindValue(":name", "furong");    if(!query.exec())    {        QSqlError lastError = query.lastError();        qDebug() << lastError.driverText() << QString(QObject::tr("INSERT failed."));    }}//查询记录query.exec("select * from automobil where id = '" + id + "'");QSqlRecord rec = query.record();qDebug() << QObject::tr("automobil table count:" ) << rec.count();while(query.next()){    for(int i = 0; i < rec.count(); i++)        qDebug() << query.value(i);}//更新记录query.prepare(QString("update automobil set name = \"quange\",name = '" + name + "' where id = %1").arg(9));if(!query.exec()){    QSqlError lastError = query.lastError();    qDebug() << lastError.driverText() << QString(QObject::tr("update failed."));}//删除记录query.prepare(QString("delete from automobil where id = %1").arg(2));if(!query.exec()){    qDebug() << "delete failed.";}

出现如下错误:

error: QSqlDatabase: No such file or directory 错误

解决办法:.pro工程文件中添加

QT += sql
1 0
原创粉丝点击