对于已经安装MysqL的,查看MysqL安装目录,如果安装目录下没有include和lib目录,
说明没有完全安装,需要下载mysql-connector类库,官方下载地址:http://dev.mysql.com/downloads/connector/c/
推荐课程:C语言教程。
部分截图如下,从图左侧可看出,官网提供了c、c++、Python、J等语言的链接库,根据个人情况下载。
下面开始配置vs2008,大致需要三步。
由于我们要使用MysqL的API,并且我们机子上肯定安装了MysqL数据库,所以我们要将工程的头文件路径指向MysqL安装目录的同文件MysqL.h所在的位置,将连接库路径指向libMysqL.lib所在的路径,
这两个文件一般在include、lib目录下。
第一:将x项目属性页的C/C++->常规->附加包含目录指向MysqL.h所在的位置:C:\Program Files\MysqL\MysqL Server 5.1\include
第二:将项目属性页的链接器->常规->附加库目录指向libMysqL.lib所在的路径:C:\Program Files\MysqL\MysqL Server 5.1\lib.
第三:将链接器->输入->附加依赖项中添加libMysqL.lib。
通过上述配置后出现错误:
无法解析的外部符号 _MysqL_close@4,该符号在函数 _main 中被引用
无法解析的外部符号 _MysqL_free_result@4,该符号在函数 _main 中被引用
无法解析的外部符号 _MysqL_num_fields@4,该符号在函数 _main 中被引用
无法解析的外部符号 _MysqL_fetch_row@4,该符号在函数 _main 中被引用
无法解析的外部符号 _MysqL_store_result@4,该符号在函数 _main 中被引用
无法解析的外部符号 _MysqL_error@4,该符号在函数 _main 中被引用
无法解析的外部符号 _MysqL_real_query@12,该符号在函数 _main 中被引用
无法解析的外部符号 _MysqL_select_db@8,该符号在函数 _main 中被引用
无法解析的外部符号 _MysqL_real_connect@32,该符号在函数 _main 中被引用
无法解析的外部符号 _MysqL_init@4,该符号在
经过网友帮助,我将原来下载的64位mysql-connector卸载,又重新下了一个32位安装,结果错误消失,百思不得其解,可能是我的MysqL数据库是32位的吧。
// test9.24.cpp : 定义控制台应用程序的入口点。 // //#include <stdio.h> //#include <stdlib.h> //#include <MysqL.h> //包含MysqL所需要的头文件 //#include <WinSock2.h> //Socket,连接MysqL也需要用的 #include <windows.h> #include stdio.h #include winsock.h #include MysqL.h MysqL MysqL, *sock; //声明MysqL的句柄 int main(void) { const char * host = 127.0.0.1; //因为是作为本机测试,所以填写的是本地IP const char * user = root; //这里改为你的用户名,即连接MysqL的用户名 const char * passwd = 123; //这里改为你的用户密码 const char * db = yiersan; //这里改为你要连接的数据库的名字 unsigned int port = 3306; //这是MysqL的服务器的端口,如果你没有修改过的话就是3306。 const char * unix_socket = NULL; //unix_socket这是unix下的,我在Windows下,所以就把它设置为NULL unsigned long client_flag = 0; //这个参数一般为0 int t; const char * i_query = select * from yes_msg; //查询语句 MysqL_RES * result; //保存结果集的 www.2cto.com MysqL_ROW row; //代表的是结果集中的一行 MysqL_init(&MysqL); //连接之前必须使用这个函数来初始化 if ( (sock = MysqL_real_connect(&MysqL, host, user, passwd, db, port, unix_socket, client_flag) ) == NULL ) //连接MysqL { printf(连接失败,原因是: \n); fprintf(stderr, %s\n, MysqL_error(&MysqL)); exit(1); } else { fprintf(stderr, 连接MysqL成功!!\n); } if ( MysqL_query(&MysqL, i_query) != 0 ) //如果连接成功,则开始查询 { fprintf(stderr, 查询失败!\n); exit(1); } else { if ( (result = MysqL_store_result(&MysqL)) == NULL ) //保存查询的结果 { fprintf(stderr, 保存结果集失败!\n); exit(1); } else { while ( (row = MysqL_fetch_row(result)) != NULL ) //读取结果集中的数据,返回的是下一行。因为保存结果集时,当前的游标在第一行【之前】 { printf(name is %s\t, row[0]); //打印当前行的第一列的数据 printf(age is %s\t\n, row[1]); //打印当前行的第二列的数据 } } } MysqL_free_result(result); //释放结果集 MysqL_close(sock); scanf(%d,&t);//关闭连接 system(pause); exit(EXIT_SUCCESS); }
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。