记一次QT连接MySQL数据库中的问题

目的

目前有一个需求,是通过QT连接MySQL数据库进行数据的相关操作,首先根据网上的例子,编写了以下连接数据库的示例代码:

1. 新建了一个QT工程

2. 主体代码为:

  1. 在项目.pro文件中加入“QT+=sql”
  2. 在mainwindow.h头文件中引入必要的头
    #ifndef MAINWINDOW_H
    #define MAINWINDOW_H
    
    #include <QMainWindow>
    #include <QWidget>
    #include <QSqlDatabase>
    #include <QDebug>
    #include <QMenuBar>
    #include <QMenu>
    #include <QAction>
    
    QT_BEGIN_NAMESPACE
    namespace Ui { class MainWindow; }
    QT_END_NAMESPACE
    
    class MainWindow : public QMainWindow
    {
        Q_OBJECT
    
    public:
        MainWindow(QWidget *parent = nullptr);
        ~MainWindow();
    
        void connectMYSQL();
        void createDB();
        void initDB();
    
         QSqlDatabase database;
    
    private:
        Ui::MainWindow *ui;
    
    public slots:
            void connectDatabase();//连接数据库
    };
    #endif // MAINWINDOW_H
    
    
  3. mainwindow.cpp
#include "mainwindow.h"
#include "ui_mainwindow.h"

MainWindow::MainWindow(QWidget *parent)
    : QMainWindow(parent)
    , ui(new Ui::MainWindow)
{
    ui->setupUi(this);

    QMenuBar *menuBar = this->menuBar();
        QMenu *menuFile = menuBar->addMenu("服务器");
        QAction *openAction = menuFile->addAction("连接数据库");
        connect(openAction, &QAction::triggered, this, &MainWindow::connectDatabase);

}

MainWindow::~MainWindow()
{
    delete ui;
}

//连接数据库
void MainWindow::connectDatabase(){
    if (QSqlDatabase::contains("MySQL"))//判断testConnect连接是否存在并连接
    {
        database = QSqlDatabase::database("MySQL");
    }
    else //未连接则新建数据库连接
    {
        database=QSqlDatabase::addDatabase("QMYSQL");//创建数据库连接,并为其命名testConnect
        database.setHostName("127.0.0.1");      //连接数据库主机名,这里需要注意(若填的为”127.0.0.1“,出现不能连接,则改为localhost)
        database.setPort(3306);                 //连接数据库端口号,与设置一致
        database.setUserName("root");          //数据库用户名,与设置一致
        database.setPassword("_____");    //数据库密码,与设置一致
    }
    if(!database.open())
    {
        qDebug()<<"fail to connect mysql:";
        return;
    }
    else{
        qDebug()<<"success!";
    }
}

3. 运行后报错

QSqlDatabase: QMYSQL driver not loaded
QSqlDatabase: available drivers: QSQLITE

系统中只有SQLite的数据库驱动,这时就需要对MYSQL的驱动进行编译

4. QT下MySQL驱动编译

  1. 首先,判断当前QT的版本:
    qtcreator -version
    
    查看其中的Qt版本为5.12.8
  2. 下载该版本的Qt源码:
    自行在官网查找对应版本的qt-everywhere-src代码包
  3. 解压之后,进行编译:
    进入目录qt-everywhere-src/qtbase/src/plugins/sqldrivers/mysql,之后打开该目录下的mysql.pro项目,进行编译。

    可能需要修改部分内容,

    • 其中QMAKE_USE+=mysql注释掉
    • 然后在LIBS+=-L{libpath} -lmysqlclient
    • INCLUDEPATH+=/usr/include/mysql
      include(…/qsqldriverbase.pri)
  4. 编译生成的mysqldriver.so放在qtpaths --plugin-dir下的sqldrivers目录下。

5. 再次运行访问数据库代码

再次运行上述代码,已经可以成功连接数据库了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
要在Qt连接MySQL数据库,需要安装MySQL驱动程序。以下是连接MySQL数据库的步骤: 1. 安装MySQL驱动程序 在Qt连接MySQL数据库,需要安装Qt提供的MySQL驱动程序。可以使用Qt Maintenance Tool来安装MySQL驱动程序。打开Qt Maintenance Tool,选择“添加或删除组件”,找到“Qt版本->Qt->Qt 5.x->Qt 5.x MySQL”,然后选择安装。 2. 引入MySQL头文件 在Qt代码,需要引入MySQL头文件,包括<QSqlDatabase>、<QSqlQuery>和<QSqlError>。可以使用以下代码引入这些头文件: ```c++ #include <QSqlDatabase> #include <QSqlQuery> #include <QSqlError> ``` 3. 连接MySQL数据库 使用以下代码连接MySQL数据库: ```c++ QSqlDatabase db = QSqlDatabase::addDatabase("QMYSQL"); db.setHostName("localhost"); // 设置主机名 db.setPort(3306); // 设置端口号 db.setDatabaseName("database_name"); // 设置数据库名 db.setUserName("username"); // 设置用户名 db.setPassword("password"); // 设置密码 if (!db.open()) { qDebug() << "Failed to connect to database:" << db.lastError().text(); } ``` 其,QSqlDatabase::addDatabase()函数设置MySQL数据库驱动程序,其参数为“QMYSQL”。然后,设置主机名、端口号、数据库名、用户名和密码,并调用QSqlDatabase的open()函数连接MySQL数据库。如果连接失败,可以使用db.lastError().text()来获得错误信息。 4. 执行SQL查询 连接MySQL数据库后,可以使用以下代码执行SQL查询: ```c++ QSqlQuery query; if (!query.exec("SELECT * FROM table_name")) { qDebug() << "Failed to execute query:" << query.lastError().text(); } while (query.next()) { // 处理结果集 } ``` 其,QSqlQuery对象用于执行SQL查询,其exec()函数执行查询,next()函数用于遍历结果集。 以上就是Qt连接MySQL数据库的基本步骤。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值