免费注册 查看新帖 |

Chinaunix

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

mysql 数据库存储的错误(gtk+) [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2005-11-24 15:30 |只看该作者 |倒序浏览
各位老大,代码如下:
void save_click_ai(GtkButton *button,gpointer data)
{
        gchar query_buf[256]="insert into ai values('";
        if(my_connect()==TRUE)
        {
                if(mysql_query(mysql,"delete from ai")==0)
                {
                        for(j=0;j<row_count_ai;j++)
                        {
                                for(i=0;i<10;i++)
                                {
                                        gtk_clist_get_text(GTK_CLIST(clist_ai),j,i,&clist_data_ai[j][i]);
                                        strcat(query_buf,clist_data_ai[j][i]);
                                        strcat(query_buf,"','");
                                }
                                gtk_clist_get_text(GTK_CLIST(clist_ai),j,10,&clist_data_ai[j][10]);
                                strcat(query_buf,clist_data_ai[j][10]);
                                strcat(query_buf,"')");
                                if(mysql_query(mysql,query_buf)==0)
                                {
                                        memset(query_buf,'',sizeof(query_buf));
                                        strcpy(query_buf,"insert into ai values('");
                                }
                                else
                                        on_message((gpointer)2);
                        }
                        on_message((gpointer)1);
                }
                else
                        on_message((gpointer)3);
        }
        if(mysql_ping(mysql)==0)
                mysql_close(mysql);
        else
                on_message((gpointer)4);
}
存储成功后 导致程序结束,用的notebook容器,还有一段类似的代码,运行后直接达到的效果就是exit(0);数据库表中只能INSERT 2行。
各位老大,迫在眉睫,拜求

论坛徽章:
0
2 [报告]
发表于 2005-11-24 15:38 |只看该作者
if(mysql_query(mysql,query_buf)==0)

建议你在执行上面这一句前,把query_buf的内容打印一下,看一下生成的查询字符串是否正确。

论坛徽章:
0
3 [报告]
发表于 2005-11-24 17:20 |只看该作者
老大,我用gdb 调试,点击保存之后错误如下:

ived signal SIGSEGV, Segmentation fault.
[Switching to Thread 1080598752 (LWP 4225)]
0x42073591 in realloc () from /lib/tls/libc.so.6
(gdb) n
Single stepping until exit from function realloc,
which has no line number information.
Couldn't get registers: 没有那个进程.
(gdb)

论坛徽章:
0
4 [报告]
发表于 2005-11-24 17:44 |只看该作者
编译时用-g 选项加入调试的符号信息。
gcc -g -o output output.c

SIGSEGV, Segmentation fault

看起来应当是你的缓冲区太小,访问越界。

gchar query_buf[256]="insert into ai values('";

不知道你一行数据大概占多多少字节,你分配一个足够的缓冲区,先分配上2048个字节的缓冲区试一下。

论坛徽章:
0
5 [报告]
发表于 2005-11-24 18:13 |只看该作者
老大

[ 本帖最后由 dqk0822 于 2005-11-30 09:51 编辑 ]
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP