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
posted @   thomas_blog  阅读(2014)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!
点击右上角即可分享
微信分享提示