免费注册 查看新帖 |

Chinaunix

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

MYSQL C 接口编程遇到的一个问题,求指导。。。。。 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-09-14 22:22 |只看该作者 |倒序浏览
本帖最后由 shuimu159951 于 2011-09-14 22:25 编辑

这是在做数据包分析时出现的问题,比如我定义了一个指向http报文的指针phttp,其中http报文内容大致就是GET /WEB.......
然后插入代码如下:

char sql[100],command[10];
memmove(command,phttp,3);
sprintf(sql,"insert into http(command) values('%s')",command);
res= mysql_query(conn_ptr,sql);

但是在数据库查询的时候command一栏总是会变成GET=,每次插入都会多出一个=出来,求大家指导下这是怎么回事?

论坛徽章:
14
巨蟹座
日期:2013-11-19 14:09:4615-16赛季CBA联赛之青岛
日期:2016-07-05 12:36:0515-16赛季CBA联赛之广东
日期:2016-06-29 11:45:542015亚冠之全北现代
日期:2015-07-22 08:09:472015年辞旧岁徽章
日期:2015-03-03 16:54:15巨蟹座
日期:2014-12-29 08:22:29射手座
日期:2014-12-05 08:20:39狮子座
日期:2014-11-05 12:33:52寅虎
日期:2014-08-13 09:01:31巳蛇
日期:2014-06-16 16:29:52技术图书徽章
日期:2014-04-15 08:44:01天蝎座
日期:2014-03-11 13:06:45
2 [报告]
发表于 2011-09-15 08:24 |只看该作者
你的command只初始化了前面3个字符,所以在
memmove(command,phttp,3);
后面应该加上 command[3] = '\0';

当然,滥用拷贝还是很恶心
假如3是不变的话,用
char sql[100];
sprintf(sql,"insert into http(command) values('%.3s')",phttp);
假如3是变化的话,用
char sql[100];
sprintf(sql,"insert into http(command) values('%.*s')",3,phttp);

论坛徽章:
0
3 [报告]
发表于 2011-09-15 21:47 |只看该作者
回复 2# bruceteen


   非常感谢这位朋友的帮忙,问题解决了。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP