免费注册 查看新帖 |

Chinaunix

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

[Linux] mysql代码走到mysql_query()就报段错误 [复制链接]

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

我用codeblocks在linux下写了最简单的连接数据库执行语句代码,编译通过,SQL语句也绝对没错,但是代码走到mysql_query()就报段错误,跟踪是到mysql_send_query()和mysql_real_query()报段错误,实在是找不到什么原因,mysql也重装了还是无效,有遇到过类似情况并解决的朋友帮帮我吧,项目比较急,现在这个就是唯一的问题了....
错误信息是:program received signal SIGSEGV,Segmentation fault.In mysql_send_query() (user/lib64/mysql/libmysqlclient.so.16)
就是报这个,用终端运行的话就产生core文件段错误,查看core文件也是提示这个错误.代码是用来测试mysql的,如果OK才正式用到项目中,很基础的代码,应该没问题的

MYSQL mysql;
mysql_init(&mysql);
bool tes;
tes = mysql_real_connect(&mysql,"192.168.1.1","root","123","test",NULL,0,NULL);
char buf[512] = {0};
sprintf(buf,"select *from test");
int nRet = mysql_query(&mysql,buf);
if(nRet != 0)
{
       int nErr = mysql_rollback(&mysql);
       nRet = mysql_errno(&mysql);

}
int nErr  = mysql_commit(&mysql);
int num = mysql_affected_rows(&mysql);
printf("%d rows affected",num);

tes返回值是true.

问题的原因找到了,是因为select语句执行失败,改为insert语句就正常执行,并且也能正常将数据插入数据库,现在问题是 为什么select语句会不能正常执行呢?语句本身不可能有问题的啊

论坛徽章:
4
双子座
日期:2014-08-28 10:08:002015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:58:112015年亚洲杯之阿联酋
日期:2015-03-13 03:25:15
2 [报告]
发表于 2013-07-17 09:23 |只看该作者
错误信息至少要给一下,不然谁知道是咋回事啊

论坛徽章:
0
3 [报告]
发表于 2013-07-17 09:34 |只看该作者
回复 2# weishuo1999
错误信息是:program received signal SIGSEGV,Segmentation fault.In mysql_send_query() (user/lib64/mysql/libmysqlclient.so.16)
就是报这个,用终端运行的话就产生core文件段错误,查看core文件也是提示这个错误.


   

论坛徽章:
4
双子座
日期:2014-08-28 10:08:002015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:58:112015年亚洲杯之阿联酋
日期:2015-03-13 03:25:15
4 [报告]
发表于 2013-07-17 09:41 |只看该作者
看样子还是代码的问题

论坛徽章:
0
5 [报告]
发表于 2013-07-17 09:45 |只看该作者
回复 4# weishuo1999

mysql_send_query()这个是系统函数......是由mysql_query()函数内部调用的 不是我自己写的


   

论坛徽章:
4
双子座
日期:2014-08-28 10:08:002015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:58:112015年亚洲杯之阿联酋
日期:2015-03-13 03:25:15
6 [报告]
发表于 2013-07-17 09:49 |只看该作者
参数总是你传递的,可以把你的代码贴出来看看

论坛徽章:
0
7 [报告]
发表于 2013-07-17 10:08 |只看该作者
本帖最后由 Nathan2013 于 2013-07-17 12:27 编辑

回复 6# weishuo1999
代码是用来测试mysql的,如果OK才正式用到项目中,很基础的代码,应该没问题的

MYSQL mysql;
mysql_init(&mysql);
bool tes;
tes = mysql_real_connect(&mysql,"192.168.1.1","root","123","test",NULL,0,NULL);
char buf[512] = {0};
sprintf(buf,"select *from test");
int nRet = mysql_query(&mysql,buf);
if(nRet != 0)
{
       int nErr = mysql_rollback(&mysql);
       nRet = mysql_errno(&mysql);

}
int nErr  = mysql_commit(&mysql);
int num = mysql_affected_rows(&mysql);
printf("%d rows affected",num);

tes返回值是true.


   

论坛徽章:
0
8 [报告]
发表于 2013-07-17 10:09 |只看该作者
debug走到mysql_query()就报上面提到的那个错误了,更奇怪的是,我把代码注释了重新编译,还是走到注释的mysql_query()那里报段错误......

论坛徽章:
17
处女座
日期:2013-08-27 09:59:352015亚冠之柏太阳神
日期:2015-07-30 10:16:402015亚冠之萨济拖拉机
日期:2015-07-29 18:58:182015年亚洲杯之巴勒斯坦
日期:2015-03-06 17:38:17摩羯座
日期:2014-12-11 21:31:34戌狗
日期:2014-07-20 20:57:32子鼠
日期:2014-05-15 16:25:21亥猪
日期:2014-02-11 17:32:05丑牛
日期:2014-01-20 15:45:51丑牛
日期:2013-10-22 11:12:56双子座
日期:2013-10-18 16:28:17白羊座
日期:2013-10-18 10:50:45
9 [报告]
发表于 2013-07-17 10:20 |只看该作者
回复 7# Nathan2013


    怎么不检查mysql_real_connect返回值,怎么确定是否连接成功了,如果连接失败你后续的调用出什么错都不奇怪。

论坛徽章:
4
双子座
日期:2014-08-28 10:08:002015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:58:112015年亚洲杯之阿联酋
日期:2015-03-13 03:25:15
10 [报告]
发表于 2013-07-17 10:29 |只看该作者
你这代码问题太多了
1.没判断connect的返回
2.sprintf换乘snprintf
3.没有使用事务为何rollback回复 7# Nathan2013


   
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP