Linux(CentOS7.0)下 C访问MySQL的各种坑!!!

本文记录了在Linux CentOS-7.0环境下使用C语言连接MySQL 5.6.22的过程。作者首先尝试创建并编译了一个简单的C语言程序来获取MySQL客户端版本,但在编译过程中遇到了缺少头文件和未定义引用的问题。通过安装MySQL-devel和MySQL-shared软件包成功解决了这些问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

昨天是Linux(CentOS-7.0)下把MySQL5.6.22装上去了 ,文章地址:点击打开链接

转载请注明,原创地址:点击打开链接  http://blog.csdn.net/u010587274/article/details/50970375


今天尝试用C语言访问连接MySQL。


创建测试文件: mysqlVersion.c
[root@iZ23xz8uttcZ test]# vi mysqlVersion.c

写入一下代码:
#include <stdio.h>
#include <mysql/mysql.h>

void mysql_version( void )

{
    printf("MySQL client version : %d \n",mysql_get_client_version());
}
int main(int argc,char *argv[])
{
    mysql_version();
    return 0;
}

编译:
[root@iZ23xz8uttcZ test]# gcc -c -I /usr/include/mysql mysqlVersion.c -o mysqlVersion.o
error提示:
找不到“mysql.h”文件。
解决方案: 
[root@iZ23xz8uttcZ ~] # rpm -ivh  MySQL-devel-advanced-5.6.22-1.el7.x86_64.rpm 

链接:
[root@iZ23xz8uttcZ test]# gcc  -l mysqlclient  mysqlVersion.o -o mysqlVersion
error提示:
mysqlVersion.o: In function `mysql_version':
mysqlVersion.c:(.text+0x5): undefined reference to `mysql_get_client_version'
collect2: error: ld returned 1 exit status
解决方案:
[root@iZ23xz8uttcZ ~] # rpm -ivh  MySQL-shared-advanced-5.6.22-1.el7.x86_64.rpm
[root@iZ23xz8uttcZ ~] # rpm -ivh  MySQL-shared-compat-advanced-5.6.22-1.el7.x86_64.rpm

执行:
[root@iZ23xz8uttcZ test]# ./mysqlVersion 
MySQL client version : 50622 



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值