免费注册 查看新帖 |

Chinaunix

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

oracle 锁表的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-07-12 10:04 |只看该作者 |倒序浏览
有一张表 test_table(a,b,c)有a、b、c三个字段,有两个或者两个以上的进程同时对该表做更新update或者插入insert操作,
通过查看oracle的锁表机制,发现如果那个进程先占有test_table表后,其他进程是只能够做查询操作,如果其他进程也要对
该表作update或者insert操作的话,不知道有没有任何好的办法?请各位版主帮忙建议一下。谢谢!

论坛徽章:
0
2 [报告]
发表于 2007-07-12 10:35 |只看该作者
自己顶一下,希望大家有好的建议拿出来共享一下。

论坛徽章:
0
3 [报告]
发表于 2007-07-12 10:45 |只看该作者
例如有一个程序test.pc 对test_table表做更新或者插入操作,通过游标执行,在游标执行的循环中每50条记录就提交一下事务处理,即commit一下,这个时候就算是有其他的进程来访问test_table表的时候如果commit后,会查到修改过的记录,如果没有commit则找不到修改的记录,不知道这样做可以否?另外需要加强异常处理,在游标使用的表中建立一个日期型字段,如果在游标使用过程中出现问题,就rollback,每次打开游标的时候都要检查日期字段是否小于当前时间,小于的说明没有对test_table表做过更新,反之是更新过的,请大家发帖讨论。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP