Ubuntu下用C语言访问MySQL数据库的方法

由于项目需要,花了两天时间快速学习MySQL,首先复习了数据库的一些基础技术,接下来就是在linux下安装和测试啦。我的MySQL服务器端是安装在Windows下的(Windows下的客户端非常方便方便修改和编辑),在ubuntu下进行开发,之前老板要求将mysql的库和头文件放在程序目录下,尽量不安装依赖性的东西,因此走了一些弯路。

 

首先,安装一些开发必须的库:我是不断测试的,安装了MySQL服务器端和客户端,代 码:


sudo apt-get install mysql-server mysql-client      //如果服务器在别处,应该可以不安装服务端和客户端

 

测试连接安装在windows上的MySQL服务器:

 

mysql -h 192.168.10.106 -P 6333  -u test -p -D kk      //kk为数据库名

 

再装开发包 ,代码:
sudo apt-get install libmysqlclient15-dev     //开发包,C语言访问是必须的,最重要的。

 

下面是测试代码:

/* Simple C program that connects to MySQL Database server*/ 
#include <mysql.h> 
#include <stdio.h> 

void main() {
    MYSQL *conn;
    MYSQL_RES *res;
    MYSQL_ROW row;

 

   //设置服务器
    char *server = "192.168.10.106";
    char *user = "test";
    char *password = "test";  
    char *database = "kk";
    unsigned int port = 6333;
   
    conn = mysql_init(NULL);

    // Connect to database
    if (!mysql_real_connect(conn, server,user, password, database, port, NULL, 0)){
        fprintf(stderr, "%s/n", mysql_error(conn));
        exit(1);
    }//end of if

    // send SQL query
    if (mysql_query(conn, "show tables")) {
        fprintf(stderr, "%s/n", mysql_error(conn));
        exit(1);
    }//end of if*/

    res = mysql_use_result(conn);

    // output table name
    printf("MySQL Tables in mysql database:/n");
    while ((row = mysql_fetch_row(res)) != NULL)
    printf("%s /n", row[0]);

    // close connection
    mysql_free_result(res);
    mysql_close(conn);

}//end of method main

 

编译:(参考网上方法)


方法一:gcc test.c -o test -I/user/include/mysql                               试了一下,提示找不到了一些奇怪的错误。

我试了一下,提示找不找不到一些定义的变量。
分析:
/user/include/mysql:全是.h文件,应该应编译阶段
/user /lib/mysql:是静态库和动态库,www.linuxidc.com应该与上面的.h文件对应,用于连接阶段。

方法二:gcc test.c -o test -L/user/lib/mysql -lmysqlclient                成功!

方法三:gcc test.c -o test $(mysql_config --cflags) $(mysql_config --libs)

或者:gcc test.c -o test $(mysql_config --cflags --libs)                        成功!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值