0
点赞
收藏
分享

微信扫一扫

MySQL存储函数和存储过程习题

夜空一星 2023-07-13 阅读 38

文章目录

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_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,所以如果没有网络通信的头文件的话,就会报错。

加上下面头文件即可:

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

在这里插入图片描述

举报

相关推荐

0 条评论