免费注册 查看新帖 |

Chinaunix

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

[C++] linux下pro*c操作oracle数据库父进程和子进程同时操作的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-02-16 09:45 |只看该作者 |倒序浏览
各位兄弟姐妹, 关于父进程和子进程数据库连接的问题想请教你一下
程序结构如下:

main()
{
   connect to db;
   EXEC SQL declare ymadapter cursor for select .......;
   EXEC SQL open ymadapter;
   while(1)
  {
      EXEC SQL fetch ymadapter into.....;
      ret = fork();
     if( ret == 0 )
     {
        ......
        EXEC SQL INSERT INTO Y_BSC_SRC(.......)values(.....);
        EXEC SQL COMMIT;
        close db;
     }
  }
  EXEC SQL close ymadapter;
   close db;
}

我这样操作时而发生连接断开的错误,时而发生并发问题,时而直接崩溃掉。
请你讲解一下父进程连接了数据库后,子进程是如何继承这个连接的。最好贴出相关例程,谢谢!

论坛徽章:
1
黑曼巴
日期:2020-02-27 22:54:26
2 [报告]
发表于 2011-02-16 09:51 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
3 [报告]
发表于 2011-02-16 09:56 |只看该作者
我的主进程会先退出,因为子进程执行过程比较长,这时子进程就出现数据库连接已断开的错误

论坛徽章:
0
4 [报告]
发表于 2011-02-16 09:58 |只看该作者
回复 2# c/unix


    你有相关的例程吗?

论坛徽章:
0
5 [报告]
发表于 2011-02-16 11:01 |只看该作者
没人帮忙了吗?

论坛徽章:
0
6 [报告]
发表于 2011-02-16 14:17 |只看该作者
主进程等待子进程退出以后,再退出。
要不就在子进程中 connect db.

论坛徽章:
0
7 [报告]
发表于 2011-02-16 15:34 |只看该作者
我还是改框架吧, 用两个进程来实现,A查询库,B下载数据入库
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP