晨凯NEXT 2021-03-11 09:34 采纳率: 50%
浏览 78
已采纳

ubuntu下C语言连接mysql报错

在ubuntu下安装好了mysql,想测试一下C语言连接mysql,写了一个connect.c文件,如下

#include <stdlib.h>
#include <stdio.h>

#include "mysql.h"

int main(int argc,char *argv[])  {
	MYSQL *conn_ptr;
	conn_ptr = mysql_init(NULL);
	
	if(!conn_ptr)  {
	    fprintf(stderr,"mysql_init failed\n");
	    return EXIT_FAILURE;
	}
	
	conn_ptr = mysql_real_connect(conn_ptr,"localhost","root","xxxxxx","foo",0,NULL,0);
	
	if(conn_ptr)
		printf("Connection success\n");
	else
		printf("Connection failed\n");
	
	mysql_close(conn_ptr);
	
	return EXIT_SUCCESS;
}

结果报错,libmysqlclient.so.20:cannot open shared object file:no such file or directory,

百度了一下似乎是共享库未添加。但是这个库我已经放在usr/lib/mysql下了啊,为什么还报错?

 

  • 写回答

2条回答 默认 最新

  • 幻灰龙 2021-03-11 09:58
    关注

    路径查找问题,配置动态库查找路径。

    • 执行命令 `cat /etc/ld.so.conf` 看下动态链接库的查找路径里面是否包含 `/usr/lib/mysql/`,如果没有请添加。
    • 执行命令 `ldconfig` 将上述配置加载到缓存文件 `/etc/ld.so.cache` 里
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
  • 502203305 2021-03-11 09:57
    关注

    库放在/usr/lib64下面把,有些东西需要配置。

    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 Java环境配了,但启用不成功。
  • ¥15 求一个智能家居控制的代码
  • ¥15 ad软件 pcb布线pcb规则约束编辑器where the object matpcb布线pcb规则约束编辑器where the object matchs怎么没有+15v只有no net
  • ¥15 虚拟机vmnet8 nat模式可以ping通主机,主机也能ping通虚拟机,但是vmnet8一直未识别怎么解决,其次诊断结果就是默认网关不可用
  • ¥20 求各位能用我能理解的话回答超级简单的一些问题
  • ¥15 yolov5双目识别输出坐标代码报错
  • ¥15 这个代码有什么语法错误
  • ¥15 给予STM32按键中断与串口通信
  • ¥15 使用QT实现can通信
  • ¥15 关于sp验证的一些东西,求告知如何解决,