缘起:有同学今天问老男孩C程序访问mysql问题,特写此文。
1、c程序访问mysql代码 #include <stdio.h> #include <stdlib.h> #include <mysql.h> #define DB_SERVER "192.168.10.33" #define DB_NAME "ddource" #define DB_USER "oldboy" #define DB_PWD "oldboy123" static MYSQL *db_handel,mysql; static MYSQL_ROW row; static int query_error; MYSQL_RES *query_test( char *sql); int query_show(MYSQL_RES *result); int main( int argc, char *argv[]) { MYSQL_RES * results; results=query_test( "select upper(DOC) from t_doc limit 30;" ); //获取记录 query_show(results); //显示记录 return 0; } //查询记录 MYSQL_RES *query_test( char *sql) { static MYSQL_RES *query_result; printf( "%s\n" ,sql); mysql_init(&mysql); db_handel=mysql_real_connect(&mysql,DB_SERVER,DB_USER,DB_PWD,DB_NAME,0,0,0); //打开数据库连接 if (db_handel==NULL) //错误处理 { printf(mysql_error(&mysql)); return NULL; } query_error=mysql_query(db_handel, "set names utf8" ); //查询 query_error=mysql_query(db_handel,sql); //查询 if (query_error!=0) //错误处理 { printf(mysql_error(db_handel)); return NULL; } query_result=mysql_store_result(db_handel); //获取记录 mysql_close(db_handel); //关闭数据库 return query_result; //返回记录 } //显示记录 int query_show(MYSQL_RES *result) { unsigned int i,num_fields; MYSQL_FIELD *fileds; num_fields=mysql_num_fields(result); //获取字段数 fileds=mysql_fetch_fields(result); //获取字段数组 while ((row=mysql_fetch_row(result))!=NULL) //循环显示 { for (i=0;i<num_fields;i++) { //正式操作这里通过fwrite写入到文件 printf( "%s \t" ,row[i]); } printf( "\n" ); } return 0; } 2、编译 [root@test oldboy]# gcc -o select select.c -lmysqlclient -I/usr/local/webserver/mysql/include/mysql/ -L/usr/local/webserver/mysql/lib/mysql/ 3、执行 [root@test oldboy]# ./select ./select: error while loading shared libraries: libmysqlclient.so.15: cannot open shared object file: No such file or directory [root@test oldboy]# find / -name libmysqlclient.so.15 /usr/local/webserver/mysql/lib/mysql/libmysqlclient.so.15 报错了...。 4、问题原因: 出现上面的错误是因为系统运行的时候没有找到程序运行所需要的libmysqlclient.so.15运行库文件,解决方法有两个: 方法一:直接把libmysqlclient.so.15这个文件拷贝到系统指定的/usr/lib库文件目录中。 方法二:设置/etc/ld.so.conf文件,编辑该文件,在文件中加入libmysqlclient.so.15所在目录,保存退出。需要注意的是,每次改动ld.so.conf之后需要运行ldconfig来确认刷新。 方法三:Add /usr/local/mysql/lib/mysql to you LD_LIBRARY_PATH environment variable 5、最终解决办法: 如果出上面的提示可以通过下面的方法解决: [root@test oldboy]# vi /etc/ld.so.conf include ld.so.conf.d/*.conf /usr/ofed/lib /usr/local/webserver/mysql/lib /usr/local/webserver/mysql/lib/mysql #---------------------- 执行ldconfig 生效 6、ldconfig使用方法: ldconfig [options] [libs] 命令ldconfig决定位于目录/usr/lib和/lib下的共享库所需的运行的链接,这些链接在命令行上的libs指定并被保存在 /etc/ld.so.conf中。命令ldconfig和动态链接/装载工具ld.so协同工作,一起来创建和维护对最新版本共享库的链接。 ldconfig的两个选项 -p:仅打印出文件/etc/ld.so.cache的内容,此文件是ld.so所知道的共享库的当前列表 -v:更新/etc/ld.so.cache的内容,列出每个库的版本号,扫描的目录和所有创建和更新的链接linux下c程序访问mysql小例子
最新推荐文章于 2022-03-13 17:13:33 发布