MySQL “error: ‘fd’: 未知重写说明符”

1、【问题】MySQL “error: ‘fd’: 未知重写说明符”

有以下代码,mysqlincludelib 都已经加入附加目录,libmysql.lib 已经加入依赖库:

#pragma once
#pragma comment(lib, "libmysql.lib")

#include <mysql.h>
#include <string>
using std::string;

int main()
{
    
    
    ......
    return 0;
}

当编译时遇到如下错误:

mysql server 5.5\include\mysql_com.h(291): error C3646: “fd”: 未知重写说明符
mysql server 5.5\include\mysql_com.h(291): error C4430: 缺少类型说明符 - 假定为 int
mysql server 5.5\include\mysql_com.h(470): error C2065: “SOCKET”: 未声明的标识符
mysql server 5.5\include\mysql_com.h(470): error C2146: 语法错误: 缺少“)”(在标识符“s”的前面)

在这里插入图片描述
很明显,mysql_com.hmysql 提供的头文件,这里并未涉及我编写的代码。

2、【解决】增加引用头文件

当用C/C++ 连接数据库并且采用ODBC(Open DataBases Connection) 肯定会出现
#include 这个头文件,关键就是这个头文件的问题,以前写程序都没考虑过头文件摆放次序的问题,这次的问题让我大开眼界。

在预编译 #include <mysql.h> 一定要先包含 #include <winsock.h> 这个头文件才不会出现刚才的问题。

winsock.h这个头文件一定要在mysql.h的头文件前面。

  • 原因:
    • #include "mysql.h"中调用了mysql_com.h,而mysql_com.h使用了有关网络套接字的fd,所以如果没有网络通信的头文件的话,就会报错。

加上下面头文件即可:

#include <WinSock2.h>//必须要有,解决“fd”:未知重写说明符

#ifdef _MSC_VER
	#ifdef _WIN64
	#include <WinSock2.h>
	#elif _WIN32
	#include <winsock.h>
	#endif
#endif

在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/qq_44918090/article/details/131671002
fd