QSqlDatabase数据库

#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
  • 4
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值