C/C++笔记-使用mysql-connector-c连接mysql数据库

本文介绍了MySQLConnector/C库的Windows(libmysql.lib)和Linux(mysqlclient.lib)版本的区别,以及如何在Qt项目中使用它们,特别是在Windows上使用VisualStudio和在Linux上使用GCC的情况。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

驱动在这个地方下载:

MySQL :: Download MySQL Connector/C (Archived Versions)

我下载的是:mysql-connector-c-6.1.11-winx64

解压后lib有2个,一个是libmysql.lib一个是mysqlclient.lib

他们的区别如下:

libmysql.lib 和 mysqlclient.lib 都是 MySQL C Connector 的库文件,但它们针对不同的操作系统和编译器。

libmysql.lib 是 Windows 平台上使用的库文件,它是使用 Visual Studio 编译器编译的。这个库文件包含了 MySQL C Connector 的所有功能,包括连接 MySQL 数据库、执行 SQL 语句、处理结果集等。

mysqlclient.lib 是 Linux 平台上使用的库文件,它是使用 GCC 编译器编译的。这个库文件也包含了 MySQL C Connector 的所有功能。

因此,如果你在 Windows 平台上使用 Visual Studio 编译器,你应该使用 libmysql.lib;如果你在 Linux 平台上使用 GCC 编译器,你应该使用 mysqlclient.lib。

但他们的include文件是一样的,所以只要链接好对应的lib库,就可以跨平台了。

下面给出C++相关的代码,用的是Qt的pro管理项目:

QT -= gui

CONFIG += c++11 console
CONFIG -= app_bundle

INCLUDEPATH += D:\mysql\mysql-connector-c-6.1.11-winx64\include
LIBS += -LD:\mysql\mysql-connector-c-6.1.11-winx64\lib -llibmysql

# You can make your code fail to compile if it uses deprecated APIs.
# In order to do so, uncomment the following line.
#DEFINES += QT_DISABLE_DEPRECATED_BEFORE=0x060000    # disables all the APIs deprecated before Qt 6.0.0

SOURCES += \
        main.cpp

# Default rules for deployment.
qnx: target.path = /tmp/$${TARGET}/bin
else: unix:!android: target.path = /opt/$${TARGET}/bin
!isEmpty(target.path): INSTALLS += target

main.cpp如下:

#include <QCoreApplication>
#include <mysql.h>
#include <stdio.h>

int main(int argc, char *argv[])
{
    QCoreApplication a(argc, argv);

    MYSQL *conn;
    MYSQL_RES *res;

    const char *server = "localhost";
    const char *user = "root";
    const char *password = "root";

    conn = mysql_init(NULL);
    if(!mysql_real_connect(conn, server, user, password, NULL, 0, NULL, 0)){

        fprintf(stderr, "%s\n", mysql_error(conn));
        return -1;
    }

    printf("MySQL version: %s\n", mysql_get_server_info(conn));
    mysql_close(conn);

    return a.exec();
}

运行结果如下:

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

IT1995

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

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

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

打赏作者

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

抵扣说明:

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

余额充值