QSqlDatabase二三事

目录

0.前言

1.连接

创建连接

自定义的连接名

2.操作

打开数据库

事务操作

3.问题

4.参考


0.前言

QSqlDatabase 类用于处理与数据库的连接,提供用于通过连接访问数据库的接口,一个 QSqlDatabase 实例就代表了一个连接。

Qt 数据库模块使用前需在 pro 工程文件中加上:Qt += sql

引入头文件后,看看有哪些驱动:

qDebug()<<QSqlDatabase::drivers();
// ("QSQLITE", "QMYSQL", "QMYSQL3", "QODBC", "QODBC3", "QPSQL", "QPSQL7")

(从 Qt5.12.4 开始默认没有 MySQL 的驱动插件,我们需要自己编译)

1.连接

创建连接

接下来是创建连接,有三种方式:

我们一般用第一种,使用 dirver 的类型名来创建,第二个参数为连接名,如果你程序里只有一个地方操作数据库,那用默认连接名就行了:

    QSqlDatabase db;

    // 使用默认连接名
    if(QSqlDatabase::contains(QSqlDatabase::defaultConnection)){
        db = QSqlDatabase::database(QSqlDatabase::defaultConnection);
    }else{
        db = QSqlDatabase::addDatabase("QMYSQL");
    }
    //QSqlDatabase::defaultConnection 是字符串 "qt_sql_default_connection"
    
    // 使用自定义连接名
    if(QSqlDatabase::contains("MyConnection")){
        db = QSqlDatabase::database("MyConnection");
    }else{
        db = QSqlDatabase::addDatabase("QMYSQL","MyConnection");
    }

代码中先是判断了连接列表是否包含此连接,如果创建两个相同连接名的示例,会报错:

QSqlDatabasePrivate::removeDatabase: connection 'qt_sql_default_connection' is still in use, all queries will cease to work.
QSqlDatabasePrivate::addDatabase: duplicate connection name 'qt_sql_default_connection', old connection removed.

需要注意的是,连接只能在创建它的线程中使用。不支持在线程之间移动连接或者从其他线程创建查询。所以,如果我们需要多个线程操作数据库的话,可以在每个线程单独创建连接:

自定义的连接名

对于自定义的连接名,在进行查询等操作时,需要把相关类的 QSqlDatabase 设置下。不然会出现类似(QSqlQuery::exec: database not open)的错误:

此时 QSqlQuery 应该是这样构造的:

    QSqlDatabase db = QSqlDatabase::addDatabase("QMYSQL","MyConnection");
    QSqlQuery query(db);

QSqlTableModel 亦复如是;

    QSqlTableModel *model = new QSqlTableModel(this,db);

不然对应的 TableView 无法加载出数据。

2.操作

打开数据库

对于 SQLite,我们只需要设置数据库文件路径就行了:

    QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");
    //设置数据库路径,不存在则创建
    db.setDatabaseName("sqltest.db");    
    //打开数据库
    if(db.open()){
        qDebug()<<"open success";
        //关闭数据库
        db.close();
    }

如果需要在内存中创建数据库,而不是指定一个文件,可以: setDatabaseName(":memory:");

对于 MySQL,设置如下:

    // 把MySQL的配置复制粘贴过来
    db.setHostName("localhost"); 
    db.setPort(3306);
    db.setUserName("root");
    db.setPassword("qq654344883");
    // 如果不设置数据库名的话,SQL语句加上数据库名
    //sql.setDatabaseName("mysql_db");
    if(db.open()){
        qDebug()<<"open succeeded";
    }else{
        qDebug()<<"open failed";
    }

如果不设置数据库名的话,SQL 语句加上数据库名,如:

query.exec("select * from db_name.table_name;");

事务操作

提供了三个函数分别进行开启事务、提交、回滚操作:

    // 可以判断该驱动程序是否支持事务,SQLite和MySQL的是支持的
    //if(db.driver()->hasFeature(QSqlDriver::Transactions)){}
    db.transaction(); //开启事务
    //开启事务后进行增删改操作
    db.commit(); //提交
    db.rollback(); //回滚

3.问题

MySQL open 后在代码中创建的数据库,但是 QSqlTableModel 不显示内容

测试发现,在使用 MySQL 时,如果没有设置 DatabaseName ,会导致 QSqlTableModel 不显示内容。如果是在代码中创建的数据库,可以先 close() 再 open(),这样就能正常显示了。

4.参考

官方文档:https://doc.qt.io/qt-5/qsqldatabase.html

官方文档:https://doc.qt.io/qt-5/threads-modules.html

博客(Qt中操作SQLite数据库):https://blog.csdn.net/gongjianbo1992/article/details/88070605

博客(Qt5.12+VS2019编译32位MYSQL8.0驱动):https://blog.csdn.net/gongjianbo1992/article/details/105211210

 

 

 

### Qt 连接达梦数据库 QODBC 驱动未加载解决方案 当遇到 `QSqlDatabase: QODBC driver not loaded` 的问题时,通常是因为 ODBC 驱动程序未能正确加载或配置不当。以下是详细的排查和解决方法: #### 1. 确认可用驱动列表 确认当前环境中已安装并可使用的 SQL 驱动包括但不限于 `QSQLITE`, `QMYSQL`, 和 `QODBC`[^1]。 #### 2. 安装必要的依赖项 确保已经安装了适用于目标操作系统的 ODBC 驱动管理器以及特定于达梦数据库的 ODBC 驱动程序。对于 Windows 用户来说,这可能意味着下载并安装 Microsoft Data Access Components (MDAC) 或者 UnixODBC 对应版本。 #### 3. 设置环境变量 为了使应用程序能够找到所需的动态链接库(DLL),需设置 PATH 环境变量指向包含这些 DLL 文件的位置。特别是如果手动复制了任何第三方提供的插件至 Qt 插件目录,则更应该这样做。 #### 4. 复制必需的文件到指定位置 按照描述的操作指南,将相关联的 `.dll` 文件放置在适当的地方以便 Qt 能够访问它们。例如,可以考虑把 `qsqlodbc.dll` 放入 `%QT_HOME%\plugins\sqldrivers` 下面,并且同样处理其他依赖性的共享对象/模块如 `libdm8_odbc.so` 或其对应平台上的变体形式[^3]。 #### 5. 使用正确的编译工具链 选择合适的编译器非常重要;不同架构下的二进制兼容性和 ABI 差异可能会引起意想不到的问题。文中提到的例子使用了 MinGW-w64 来构建项目,因此推荐保持一致的选择以减少潜在冲突的可能性。 #### 6. 检查 PostgreSQL 相关提示 虽然问题是关于达梦而非 PostgreSQL ,但是某些通用原则仍然适用——比如避免将软件部署在一个含有空格字符在内的路径之中,因为这类情况有时会干扰命令行解析逻辑或者造成难以诊断的小错误[^4]。 通过上述措施应当有助于缓解乃至彻底解决问题。当然,具体实施细节还需参照官方文档和个人开发环境的具体情况进行调整优化。 ```cpp // 示例代码展示如何创建一个新的数据库连接 #include <QtSql/QSqlDatabase> #include <QDebug> int main() { QSqlDatabase db = QSqlDatabase::addDatabase("QODBC"); db.setHostName("your_host_name"); // 替换成实际主机名 db.setPort(your_port_number); // 替换成端口号 db.setDatabaseName("DM_DSN_NAME");// DSN 名字, 即数据源名称 bool ok = db.open(); qDebug() << "Connection successful:" << ok; } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

龚建波

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值