linux c mysql_linux c connect mysql

#include #include "mysql.h"

/*注意哦,上面也可以是mysql.h的绝对地址,一般在mysql下的include目录下,仔细看看你的在哪里?*/

int main(int argc, char *argv[])

{

MYSQL my_connection;

int res;

mysql_init(&my_connection);

/*mysql_real_connect(&mysql,host,user,passwd,dbname,0,NULL,0) == NULL)*/

if (mysql_real_connect(&my_connection, "localhost", "root", "","cusemysql",0,NULL,CLIENT_FOUND_ROWS))

{

printf("Connection success\n");

res = mysql_query(&my_connection, "insert into children values(11,'Anny',5)");

if (!res)

{

printf("Inserted %lu rows\n",(unsigned long)mysql_affected_rows(&my_connection));

/*里头的函数返回受表中影响的行数*/

}

else

{

//分别打印出错误代码及详细信息

fprintf(stderr, "Insert error %d: %s\n",mysql_errno(&my_connection),mysql_error(&my_connection));

}

mysql_close(&my_connection);

}

else

{

fprintf(stderr, "Connection failed\n");

if (mysql_errno(&my_connection))

{

fprintf(stderr, "Connection error %d: %s\n",mysql_errno(&my_connection),mysql_error(&my_connection));

}

}

return EXIT_SUCCESS;

}

/

代码写完了,要编译哦[root@zieckey mysql]# gcc -o insert insert.c

/tmp/ccyHfsX2.o(.text+0x1e): In function `main':

: undefined reference to `mysql_init'

/tmp/ccyHfsX2.o(.text+0x47): In function `main':

: undefined reference to `mysql_real_connect'

/tmp/ccyHfsX2.o(.text+0x76): In function `main':

: undefined reference to `mysql_query'

/tmp/ccyHfsX2.o(.text+0x9a): In function `main':

: undefined reference to `mysql_affected_rows'

/tmp/ccyHfsX2.o(.text+0xbc): In function `main':

: undefined reference to `mysql_error'

/tmp/ccyHfsX2.o(.text+0xcf): In function `main':

: undefined reference to `mysql_errno'

/tmp/ccyHfsX2.o(.text+0xf5): In function `main':

: undefined reference to `mysql_close'

/tmp/ccyHfsX2.o(.text+0x11f): In function `main':

: undefined reference to `mysql_errno'

/tmp/ccyHfsX2.o(.text+0x135): In function `main':

: undefined reference to `mysql_error'

/tmp/ccyHfsX2.o(.text+0x148): In function `main':

: undefined reference to `mysql_errno'

collect2: ld returned 1 exit status

[root@zieckey mysql]#

头文件和库文件位置没有指定[root@zieckey mysql]# gcc -o insert insert.c -I/usr/include/mysql/ -L/usr/lib/mysql/

/tmp/cc4gdmlp.o(.text+0x1e): In function `main':

: undefined reference to `mysql_init'

/tmp/cc4gdmlp.o(.text+0x47): In function `main':

: undefined reference to `mysql_real_connect'

/tmp/cc4gdmlp.o(.text+0x76): In function `main':

: undefined reference to `mysql_query'

/tmp/cc4gdmlp.o(.text+0x9a): In function `main':

: undefined reference to `mysql_affected_rows'

/tmp/cc4gdmlp.o(.text+0xbc): In function `main':

: undefined reference to `mysql_error'

/tmp/cc4gdmlp.o(.text+0xcf): In function `main':

: undefined reference to `mysql_errno'

/tmp/cc4gdmlp.o(.text+0xf5): In function `main':

: undefined reference to `mysql_close'

/tmp/cc4gdmlp.o(.text+0x11f): In function `main':

: undefined reference to `mysql_errno'

/tmp/cc4gdmlp.o(.text+0x135): In function `main':

: undefined reference to `mysql_error'

/tmp/cc4gdmlp.o(.text+0x148): In function `main':

: undefined reference to `mysql_errno'

collect2: ld returned 1 exit status

[root@zieckey mysql]#

gcc还是找不到头文件,下面我们可以这样,指定gcc专门找 mysqlclient 之类的库

[root@localhost testmysql]# gcc -o insert insert.c -lmysqlclient -I/usr/local/mysql/include/mysql/ -L/usr/local/mysql/lib/mysql

我用用 -lmysqlclient 选项就可以了(前面我们生成的库文件是 libmysqlclient.so.12.0.0 等,

去掉前面的lib和后面的版本标志,就剩下 mysqlclient 了所以是 -lmysqlclient )。

ok,现在我们执行看看[root@zieckey mysql]# ./insert

Connection Success

Inserted 1 rows

如果执行出错,就先执行以下三句脚本(15.0.0根据版本不同而不同)ln -s /usr/local/mysql/lib/mysql/libmysqlclient.so.15.0.0 /usr/lib/libmysqlclient.so

ln -s /usr/local/mysql/lib/mysql/libmysqlclient.so.15.0.0 /usr/lib/libmysqlclient.so.15

ln -s /usr/local/mysql/lib/mysql/libmysqlclient.so.15.0.0 /usr/lib/libmysqlclient.so.6.0.0

year,果然可以,呵呵

不信到mysql下看看表children中是否多了刚才插入的那一行数据

mysql> select * from children;

+---------+-------+------+

| childno | fname | age |

+---------+-------+------+

| 5 | 花儿 | 10 |

| 11 | Anny | 5 |

+---------+-------+------+

2 rows in set (0.00 sec)

总结:这里我们了解了MySQL数据库在Linux下的安装,以及一些基本的操作,并且我们可以通过C语言来操作MySQL数据库,这真是太令人兴奋了。欢迎大家交流

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值