c如何和mysql连接


本文摘自PHP中文网,作者(*-*)浩,侵删。

本篇文章以环境:win7 x64、vs2008、mysql为例进行讲解C如何与MySQL连接

对于已经安装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位的吧。

最后附上c连接mysql的示例代码:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

// 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);

}

以上就是c如何和mysql连接的详细内容!

相关阅读 >>

学习C语言可以用什么软件?

C语言console.writeline什么意思?

C语言函数返回值类型由什么决定?

C语言中stract函数的意思

C语言定义函数

php与C语言有什么联系和区别?

C语言绝对值怎么表示

C语言中求余运算符是什么?

C语言实现删除字符串中的数字字符

C语言volatile关键字的作用是什么?

更多相关阅读请进入《C语言》频道 >>



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...