qt中使用sqlite数据库问题

在开发过程中发现在linux系统上,qt自带的数据库模块很容易造成栈溢出,因此推荐使用外部的库

SQLiteCpp外部库安装方法

从源代码编译安装
首先,从 SQLiteCpp 的官方 GitHub 仓库(https://github.com/SRombauts/SQLiteCpp)获取源代码。可以使用git命令克隆仓库:

git clone https://github.com/SRombauts/SQLiteCpp.git


然后,进入克隆后的目录

cd SQLiteCpp


构建和安装库,通常需要使用 CMake 工具。执行以下命令:

mkdir build
cd build
cmake..
make
sudo make install(


这种方式可以获取最新版本的库,但需要安装 CMake 等构建工具,并且在安装过程中可能需要根据系统环境解决一些依赖问题。

在项目中使用 SQLiteCpp 库

一般安装好SQLite数据库与 SQLiteCpp 库qt可自动检测到两个库的位置

如果没有找到可以看一下SQLiteCpp 库的安装路径一般在默认路径/usr/local/lib里面

找到libSQLiteCpp.a和libsqlite3.a手动添加到.pro配置文件中

在.pro文件中添加 QT += sql

以下是一个简单的使用 SQLiteCpp 库进行数据库操作的示例:

简单示例

#include <iostream>
#include <SQLiteCpp/SQLiteCpp.h>

int main() {
    try {
        // 打开或创建数据库文件
        SQLite::Database db("test.db", SQLite::OPEN_READWRITE | SQLite::OPEN_CREATE);
        std::cout << "Opened database successfully" << std::endl;

        // 创建一个表
        db.exec("CREATE TABLE IF NOT EXISTS test_table (id INTEGER PRIMARY KEY, name TEXT)");
        std::cout << "Table created or already exists" << std::endl;

        // 插入数据
        SQLite::Transaction transaction(db);
        SQLite::Statement insert(db, "INSERT INTO test_table (name) VALUES ('John')");
        insert.exec();
        std::cout << "Data inserted successfully" << std::endl;
        transaction.commit();

        // 查询数据
        SQLite::Statement query(db, "SELECT * FROM test_table");
        while (query.executeStep()) {
            int id = query.getColumn(0).getInt();
            std::string name = query.getColumn(1).getString();
            std::cout << "ID: " << id << ", Name: " << name << std::endl;
        }
    } catch (const SQLite::Exception& e) {
        std::cerr << "SQLite exception: " << e.what() << std::endl;
        return 1;
    } catch (const std::exception& e) {
        std::cerr << "General exception: " << e.what() << std::endl;
        return 1;
    }
    return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值