免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1964 | 回复: 2
打印 上一主题 下一主题

[C] C语言查询mysql中数据的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-03-22 14:12 |只看该作者 |倒序浏览
数据库的表名为offlinemsg
结构为:
uid int not null,
msg varchar(1024) not null

写了一段查询数据的C代码:
  1.         MYSQL mysql;
  2.         MYSQL_RES *res;
  3.         MYSQL_ROW row;
  4.         int rows;
  5.         int t;
  6.         int uid=1;
  7.         char query[128];
  8.         char buff[1024]={0};
  9.         memset(query,0,128);
  10.         sprintf(query,"select msg from offlinemsg where uid=%d",uid);
  11.         mysql_init(&mysql);
  12.         if ( !mysql_real_connect(&mysql,DB_HOST, DB_USERNAME, DB_PWD, DB_USERDB,0,NULL,0) )
  13.                 printf( "Error connecting to database: %s\n",mysql_error(&mysql));
  14.         t = mysql_real_query(&mysql,query,(unsigned int)strlen(query));
  15.         if( t )
  16.                 printf("Error making query: %s\n",mysql_error(&mysql));
  17.         res = mysql_store_result(&mysql);
  18.         row = mysql_fetch_row(res);
  19.         rows=(int)mysql_num_rows(res);
  20.         printf("rows=%d\n",rows);
  21.         int n=0;
  22.         for(n;n<rows;n++)
  23.                 printf("%s\n",row[n]);
  24.         mysql_free_result(res);
复制代码
可是结果确是:
第一行显示正确,后面显示乱码,类似“id??  der="Bin????  ""
因该不是字符集的问题吧 我都没有用中文

论坛徽章:
0
2 [报告]
发表于 2010-03-22 14:52 |只看该作者
是不是终端显示的编码有问题?

论坛徽章:
0
3 [报告]
发表于 2010-03-22 22:15 |只看该作者
回复 2# rain_fish


    应该不是的
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP