缘起:有同学今天问老男孩C程序访问mysql问题,特写此文。       

    1、c程序访问mysql代码 #include <stdio.h>  
  1. #include <stdlib.h>  
  2. #include <mysql.h>  
  3.  
  4. #define DB_SERVER "192.168.10.33"  
  5. #define DB_NAME "ddource"  
  6. #define DB_USER "oldboy"  
  7. #define DB_PWD  "oldboy123"  
  8.  
  9. static MYSQL *db_handel,mysql;  
  10. static MYSQL_ROW row;  
  11. static int query_error;  
  12.  
  13. MYSQL_RES *query_test(char *sql);  
  14. int query_show(MYSQL_RES *result);  
  15. int main(int argc,char *argv[])  
  16. {  
  17.         MYSQL_RES * results;  
  18.         results=query_test("select upper(DOC) from t_doc limit 30;");//获取记录  
  19.         query_show(results);//显示记录  
  20.         return 0;  
  21. }  
  22.  
  23. //查询记录  
  24. MYSQL_RES *query_test(char *sql)  
  25. {  
  26.         static MYSQL_RES *query_result;  
  27.         printf("%s\n",sql);  
  28.         mysql_init(&mysql);  
  29.         db_handel=mysql_real_connect(&mysql,DB_SERVER,DB_USER,DB_PWD,DB_NAME,0,0,0);//打开数据库连接  
  30.         if(db_handel==NULL)//错误处理  
  31.         {  
  32.                 printf(mysql_error(&mysql));  
  33.                 return NULL;  
  34.         }  
  35.  
  36.         query_error=mysql_query(db_handel,"set names utf8");//查询  
  37.         query_error=mysql_query(db_handel,sql);//查询  
  38.         if(query_error!=0)//错误处理  
  39.         {  
  40.                 printf(mysql_error(db_handel));  
  41.                 return NULL;  
  42.         }  
  43.         query_result=mysql_store_result(db_handel);//获取记录  
  44.         mysql_close(db_handel);//关闭数据库  
  45.         return query_result;//返回记录  
  46. }  
  47. //显示记录  
  48. int query_show(MYSQL_RES *result)  
  49. {  
  50.         unsigned int i,num_fields;  
  51.         MYSQL_FIELD *fileds;  
  52.         num_fields=mysql_num_fields(result);//获取字段数  
  53.         fileds=mysql_fetch_fields(result);//获取字段数组  
  54.         while((row=mysql_fetch_row(result))!=NULL)//循环显示  
  55.         {  
  56.                 for(i=0;i<num_fields;i++)  
  57.                 {  
  58.                     //正式操作这里通过fwrite写入到文件  
  59.             printf("%s \t",row[i]);  
  60.                 }  
  61.           
  62.             printf("\n");  
  63.     }  
  64.         return 0;  
  65. }  
  66.  
  67. 2、编译  
  68. [root@test oldboy]# gcc -o select select.c -lmysqlclient -I/usr/local/webserver/mysql/include/mysql/ -L/usr/local/webserver/mysql/lib/mysql/  
  69. 3、执行  
  70. [root@test oldboy]# ./select   
  71. ./select: error while loading shared libraries: libmysqlclient.so.15: cannot open shared object file: No such file or directory  
  72. [root@test oldboy]# find / -name libmysqlclient.so.15  
  73. /usr/local/webserver/mysql/lib/mysql/libmysqlclient.so.15  
  74. 报错了...。  
  75.  
  76. 4、问题原因:  
  77. 出现上面的错误是因为系统运行的时候没有找到程序运行所需要的libmysqlclient.so.15运行库文件,解决方法有两个:  
  78. 方法一:直接把libmysqlclient.so.15这个文件拷贝到系统指定的/usr/lib库文件目录中。  
  79. 方法二:设置/etc/ld.so.conf文件,编辑该文件,在文件中加入libmysqlclient.so.15所在目录,保存退出。需要注意的是,每次改动ld.so.conf之后需要运行ldconfig来确认刷新。  
  80. 方法三:Add /usr/local/mysql/lib/mysql to you LD_LIBRARY_PATH environment variable  
  81.  
  82. 5、最终解决办法:  
  83. 如果出上面的提示可以通过下面的方法解决:  
  84. [root@test oldboy]# vi /etc/ld.so.conf  
  85. include ld.so.conf.d/*.conf  
  86. /usr/ofed/lib  
  87. /usr/local/webserver/mysql/lib  
  88. /usr/local/webserver/mysql/lib/mysql  
  89. #----------------------  
  90. 执行ldconfig 生效  
  91.  
  92. 6、ldconfig使用方法:   
  93. ldconfig [options] [libs]  
  94. 命令ldconfig决定位于目录/usr/lib和/lib下的共享库所需的运行的链接,这些链接在命令行上的libs指定并被保存在 /etc/ld.so.conf中。命令ldconfig和动态链接/装载工具ld.so协同工作,一起来创建和维护对最新版本共享库的链接。  
  95. ldconfig的两个选项  
  96. -p:仅打印出文件/etc/ld.so.cache的内容,此文件是ld.so所知道的共享库的当前列表  
  97. -v:更新/etc/ld.so.cache的内容,列出每个库的版本号,扫描的目录和所有创建和更新的链接 

 http://dev.mysql.com/doc/refman/5.1/en/c-api-functions.html