網站首頁 編程語言 正文
Oracle模擬事務提交、表鎖,處理表鎖問題
1.查看AutoCommit
# 我當前自動提交設置為OFF,即默認不自動提交
SYS@helowin>show autocommit;
autocommit OFF
# 可通過set命令,選擇是否開啟自動提交事務
SYS@helowin>set auto
SP2-0281: autocommit missing set option
Usage: SET AUTO[COMMIT] { OFF | ON | IMM[EDIATE] | n }
2.手動提交事務流程
通過可視化工具navicat執行插入語句,發現雖然我們設置了不自動提交,這里還是插入成功了。因為有些可視化工具會幫你commit。
我們打開終端,發現通過剛剛的操作已經存在一條數據
SYS@helowin>select * from zxy.study;
ID NAME TESTTIME
---------- -------------------- --------------------------------------------------
1 a 2022-09-26
我們打開兩個終端頁面,先在終端一中模擬插入一條數據,不執行commit??唇K端二中是否能看到插入的數據
2.1 終端一 尚未commit
# 在終端一模擬插入一條數據,不commit
SYS@helowin>insert into zxy.study values(2,'b','2022-09-26');
1 row created.
# 發現在當前終端中可以查到數據
# 在事務提交之前,只有操作數據庫的這個人才能看到所做的事,別人只能等待提交后才可以
SYS@helowin>select * from zxy.study;
ID NAME TESTTIME
---------- -------------------- --------------------------------------------------
2 b 2022-09-26
1 a 2022-09-26
2.2 終端二 查詢
# 在終端二中不能查到數據
SYS@helowin>select * from zxy.study;
ID NAME TESTTIME
---------- -------------------- --------------------------------------------------
1 a 2022-09-26
2.3 終端一 commit
SYS@helowin>commit;
Commit complete.
SYS@helowin>select * from zxy.study;
ID NAME TESTTIME
---------- -------------------- --------------------------------------------------
2 b 2022-09-26
1 a 2022-09-26
2.4 終端二 查詢
SYS@helowin>select * from zxy.study;
ID NAME TESTTIME
---------- -------------------- --------------------------------------------------
2 b 2022-09-26
1 a 2022-09-26
3.模擬表鎖
開啟事務,但是一直未提交,會造成表鎖
3.1 在終端一開啟一個事務,但是不提交
SYS@helowin>insert into zxy.study values(3,'c','2022-09-26');
1 row created.
SYS@helowin>select * from zxy.study;
ID NAME TESTTIME
---------- -------------------- --------------------------------------------------
2 b 2022-09-26
3 c 2022-09-26
1 a 2022-09-26
3.2 查詢是否有表鎖情況
select sess.sid,
sess.serial#,
lo.oracle_username,
lo.os_user_name,
ao.object_name,
lo.locked_mode
from v$locked_object lo, dba_objects ao, v$session sess
where ao.object_id = lo.object_id
and lo.session_id = sess.sid;
3.3 關閉該條未commit的事務
alter system kill session 'sid,serial#';
原文鏈接:https://blog.csdn.net/m0_51197424/article/details/127054500
相關推薦
- 2022-07-06 pandas實現一行拆分成多行_python
- 2022-07-06 C#winform中數據庫綁定DataGrid的實現_C#教程
- 2022-04-18 create-react-app 中支持sass,怎么搞?
- 2022-10-21 golang?一次性定時器Timer用法及實現原理詳解_Golang
- 2022-08-20 使用Docker制作Python環境連接Oracle鏡像_python
- 2021-11-03 C++趣味算法之偵探推理_C 語言
- 2023-12-13 idea git只查看某個人提交的代碼記錄
- 2022-09-20 Go?Redis客戶端使用的兩種對比_Golang
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支