免费注册 查看新帖 |

Chinaunix

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

关于ORACLE的锁的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2005-08-15 09:59 |只看该作者 |倒序浏览
我想了解一下ORACLE的锁是如何管理的,需要程序员自己设置锁,管理锁吗?
我现在遇到这个情况
我的系统是C/S的,后台用ORACLE数据库(非三层的,直接是应用程序连ORACLE),客户端是WINDOWS下通过DELPHI的BDE连的,数据库是ORACLE9。2。0。2,服务器是SUN,
最近客户端在录数据时,老是锁冲突,导致数据录入长时间等待进入死锁了,
以大家的看法,这是客户端的问题呢?还是服务器端的设置有问题?
我们写客户端程序时,重来没有针对锁做过任何操作(让服务器自己管理),都没问题的呀?
纳闷!

下面是出问题时锁的简单情况
USERNAME |SID| LOCK_TYPE|OBJ_NAME|OBJ_TYPE
SCUSER       47    TX                                          
SCUSER       47    TM               DBA01         TABLE

论坛徽章:
0
2 [报告]
发表于 2005-08-15 11:26 |只看该作者

关于ORACLE的锁的问题

锁是和你的程序有关系的,比如,update 等修改操作后,没有及时提交或回滚,别人就会等锁,或者select模式取数据加有for update选项,
别的程序也以模式取数据,在一方没有及时提交和回滚的时候就会等锁。
一般都是你的程序涉及问题,和数据库本身没有关系。

招聘 : Linux运维
论坛徽章:
0
3 [报告]
发表于 2005-08-15 11:55 |只看该作者

关于ORACLE的锁的问题

一般不需要特别管理的
看看你哪个事务提交的不太及时吧

论坛徽章:
0
4 [报告]
发表于 2005-08-15 12:44 |只看该作者

关于ORACLE的锁的问题

问题是出问题的应用程序是无源码的。
我想知道如何查出ORACLE系统中锁状态,应该写什么样的语句?
我查V_$LOCK信息太简单了?
我想查看锁的什么对象该怎么办?

招聘 : Linux运维
论坛徽章:
0
5 [报告]
发表于 2005-08-15 13:03 |只看该作者

关于ORACLE的锁的问题

v$lock
v$lock_object
v$transaction_enqueue
V$TRANSACTION_ENQUEUE displays locks owned by transaction state objects.

V$TRANSACTION
V$TRANSACTION lists the active transactions in the system

就能想到这几个了
试试把

论坛徽章:
0
6 [报告]
发表于 2005-08-16 12:46 |只看该作者

关于ORACLE的锁的问题

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

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP