• c++连接mysql并提示“无法解析的外部符号 _mysql_server_init@12”解决方法&提示缺少“libmysql.dll”


    课程作业要用c++连接mysql server,但是出现些小问题,经查阅资料已经解决,做一下笔记。

    环境:vs2017, mysql版本是8.0.16-winx64。

    设置项目属性

      项目 -  C/C++ - 常规 - 附加包含目录 里面添加 C:mysqlmysql-8.0.16-winx64include。  大家依葫芦画瓢,改成自己的相应目录。

       项目 - 配置属性 - 链接器 - 常规 - 附加库目录, 添加C:mysqlmysql-8.0.16-winx64lib。 也是要换成自己的目录。

      项目 - 配置属性 - 链接器 - 输入 - 附加依赖项    添加libmysql.lib.

     其实就是将头文件和库文件包含进来。

    测试程序

     1 //下面的代码是一个实现C++连接MYSQL数据库的很好的例子
     2 
     3 #include <winsock.h>
     4 #include <iostream>
     5 #include <string>
     6 #include <mysql.h>
     7 using namespace std;
     8 
     9 #pragma comment(lib, "ws2_32.lib")
    10 #pragma comment(lib, "libmysql.lib")
    11 //单步执行,不想单步执行就注释掉
    12 #define STEPBYSTEP
    13 
    14 int main() {
    15     cout << "****************************************" << endl;
    16 
    17 #ifdef STEPBYSTEP
    18     system("pause");
    19 #endif
    20 
    21     //必备的一个数据结构
    22     MYSQL mydata;
    23 
    24     //初始化数据库
    25     if (0 == mysql_library_init(0, NULL, NULL)) {
    26         cout << "mysql_library_init() succeed" << endl;
    27     }
    28     else {
    29         cout << "mysql_library_init() failed" << endl;
    30         return -1;
    31     }
    32 
    33 #ifdef STEPBYSTEP
    34     system("pause");
    35 #endif
    36 
    37     //初始化数据结构
    38     if (NULL != mysql_init(&mydata)) {
    39         cout << "mysql_init() succeed" << endl;
    40     }
    41     else {
    42         cout << "mysql_init() failed" << endl;
    43         return -1;
    44     }
    45 
    46 
    47 
    48 #ifdef STEPBYSTEP
    49     system("pause");
    50 #endif
    51 
    52     //在连接数据库之前,设置额外的连接选项
    53     //可以设置的选项很多,这里设置字符集,否则无法处理中文
    54     if (0 == mysql_options(&mydata, MYSQL_SET_CHARSET_NAME, "gbk")) {
    55         cout << "mysql_options() succeed" << endl;
    56     }
    57     else {
    58         cout << "mysql_options() failed" << endl;
    59         return -1;
    60     }
    61 
    62 #ifdef STEPBYSTEP
    63     system("pause");
    64 #endif
    65 
    66     //连接数据库
    67     if (NULL != mysql_real_connect(&mydata, "localhost", "root", "123456", "mysql",3306, NULL, 0))   //这里的地址,用户名,密码,端口可以根据自己本地的情况更改
    68     {
    69         cout << "mysql_real_connect() succeed" << endl;
    70     }
    71     else {
    72         cout << "mysql_real_connect() failed" << endl;
    73         return -1;
    74     }
    75 
    76     return 0;
    77 }

    如果能运行,OK!后面的不用看了。

    问题

    无法解析的外部符号 _mysql_real_connect...

    方法一:由于VS建立的项目默认为WIN32 项目,需将平台改为64。设置如下:

    (1) 项目—》属性—》配置属性—》配置管理器—》活动解决方案平台,下拉选新建,出现一个新的对号框,在键入选择新平台中选择X64,如下图所示:


    (2)不是将C:mysqlmysql-8.0.16-winx64lib(安装MySql下的lib文件夹)中的libmysql.dll拷到项目下的Debug文件夹中,而是拷到项目下x64Debug中(或者C:WindowsSystem32中)。重启(必需的)。完毕。。  

    没有第二步会提示缺少“libmysql.dll”。

    参考链接:

    1. c++连接mysql并提示“无法解析的外部符号 _mysql_server_init@12”解决方法

    2. VS中MFC连接MySQL由于系统不同位(32/64)引起的错误:无法解析的外部符号 _mysql_init@4、_mysql_query 

    3. 测试代码

  • 相关阅读:
    Java实现 LeetCode 130 被围绕的区域
    Java实现 LeetCode 130 被围绕的区域
    Java实现 LeetCode 130 被围绕的区域
    win32创建控件的一些问题
    win32 sdk绘制ListBox控件
    VC++ WIN32 sdk实现按钮自绘详解 之二.
    win32 sdk 列表视图控件绘制
    win32 sdk树形控件的项拖拽实现
    MFC 用gdi绘制填充多边形区域
    vc 按钮自绘
  • 原文地址:https://www.cnblogs.com/lfri/p/10821407.html
Copyright © 2020-2023  润新知