QT之项目经验(windows下的sqlite,c++开发)

在Windows下使用Qt进行SQLite数据库开发,你需要确保Qt的SQL模块已经正确配置并且包含了SQLite驱动。以下是一个简单的例子,展示了如何在Qt中使用SQLite数据库:




#include <QSqlDatabase>
#include <QSqlQuery>
#include <QDebug>
 
int main(int argc, char *argv[])
{
    // 初始化Qt应用程序
    QCoreApplication a(argc, argv);
 
    // 添加SQLite数据库
    QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");
    db.setDatabaseName("path_to_your_database.sqlite");
 
    // 尝试打开数据库
    if (!db.open()) {
        qDebug() << "无法打开数据库!";
        return -1;
    }
 
    // 创建一个QSqlQuery对象来执行SQL命令
    QSqlQuery query;
 
    // 执行一个SQL命令,例如创建一个表
    bool success = query.exec("CREATE TABLE IF NOT EXISTS people (id INTEGER PRIMARY KEY, name TEXT, age INTEGER)");
    if (!success) {
        qDebug() << "创建表失败:" << query.lastError();
    }
 
    // 插入数据
    success = query.exec("INSERT INTO people (name, age) VALUES ('Alice', 30)");
    if (!success) {
        qDebug() << "插入数据失败:" << query.lastError();
    }
 
    // 查询数据
    success = query.exec("SELECT * FROM people");
    if (!success) {
        qDebug() << "查询数据失败:" << query.lastError();
    } else {
        while (query.next()) {
            int id = query.value(0).toInt();
            QString name = query.value(1).toString();
            int age = query.value(2).toInt();
            qDebug() << id << name << age;
        }
    }
 
    // 关闭数据库
    db.close();
 
    return a.exec();
}

在这个例子中,我们首先设置了数据库,然后尝试打开它。如果数据库成功打开,我们就可以使用QSqlQuery来执行SQL命令,例如创建表、插入数据和查询数据。最后,我们关闭数据库并结束应用程序。

确保你的Qt开发环境已经安装了SQLite驱动。如果没有,你可能需要下载并安装SQLite的Qt驱动插件。在Qt 5.15及以后版本中,SQLite驱动是默认包含的,所以这可能不是一个问题。

这个例子只是一个简单的展示如何在Qt中使用SQLite的入门级例子。在实际的项目中,你可能需要进行更复杂的数据库操作,例如事务处理、并发控制等。

sql
最后修改于:2024年09月03日 18:12

评论已关闭

推荐阅读

DDPG 模型解析,附Pytorch完整代码
2024年11月24日
DQN 模型解析,附Pytorch完整代码
2024年11月24日
AIGC实战——Transformer模型
2024年12月01日
Socket TCP 和 UDP 编程基础(Python)
2024年11月30日
python , tcp , udp
如何使用 ChatGPT 进行学术润色?你需要这些指令
2024年12月01日
AI
最新 Python 调用 OpenAi 详细教程实现问答、图像合成、图像理解、语音合成、语音识别(详细教程)
2024年11月24日
ChatGPT 和 DALL·E 2 配合生成故事绘本
2024年12月01日
omegaconf,一个超强的 Python 库!
2024年11月24日
【视觉AIGC识别】误差特征、人脸伪造检测、其他类型假图检测
2024年12月01日
[超级详细]如何在深度学习训练模型过程中使用 GPU 加速
2024年11月29日
Python 物理引擎pymunk最完整教程
2024年11月27日
MediaPipe 人体姿态与手指关键点检测教程
2024年11月27日
深入了解 Taipy:Python 打造 Web 应用的全面教程
2024年11月26日
基于Transformer的时间序列预测模型
2024年11月25日
Python在金融大数据分析中的AI应用(股价分析、量化交易)实战
2024年11月25日
AIGC Gradio系列学习教程之Components
2024年12月01日
Python3 `asyncio` — 异步 I/O,事件循环和并发工具
2024年11月30日
llama-factory SFT系列教程:大模型在自定义数据集 LoRA 训练与部署
2024年12月01日
Python 多线程和多进程用法
2024年11月24日
Python socket详解,全网最全教程
2024年11月27日