oracle更新user_tables,python-如何在Oracle上锁定user_tables?

我有一台机器的回溯,其中以下查询似乎挂了好几天:

SELECT table_name FROM user_tables

有什么可能产生这样的锁?用户永远不能修改该表;并且此查询的许多后续实例均成功运行.

解决方法:

因此,由于条件不再存在,因此无法判断发生了什么.

但是,将来,如果再次发生这种情况或类似情况,则需要使用Oracle的wait接口.即,查看V $SESSION.

首先,您需要确定进程是在旋转(即在CPU上)还是正在阻塞(即在等待等待事件).确定该状态的方法是查看STATE列:

>如果状态为“正在等待”,则会话被阻止.如果是这样,则EVENT列应描述会话正在等待什么事件.

>如果状态不是“等待”,则会话在CPU上,而EVENT列是它等待的最后一件事.

>如果状态为“等待的已知时间”,则WAIT_TIME是等待的时间(以毫秒为单位).

>如果状态为“等待的短时间”,则会话等待的时间少于一秒.

>如果STATE是’WAITED UNKNOWN TIME’,则等待的时间未知,因为该会话的timed_statistics设置为FALSE.

希望能有所帮助.

标签:oracle,locking,cx-oracle,database-locking,python

来源: https://codeday.me/bug/20191201/2082138.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值