網站首頁 編程語言 正文
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-10-06 SQL語句中的ON?DUPLICATE?KEY?UPDATE使用_MsSql
- 2022-06-22 Android使用http實現注冊登錄功能_Android
- 2022-11-25 C語言中atoi函數模擬實現詳析_C 語言
- 2022-12-24 C語言中的逗號運算符詳解_C 語言
- 2022-02-24 forEach直接改變原數組對象中的某一個屬性
- 2024-03-28 mac vscode 命令行啟動命令安裝 別名設置方法
- 2023-07-04 spring boot security驗證碼登錄示例
- 2022-10-23 python如何在一個py文件中獲取另一個py文件中的值(一個或多個)_python
- 最近更新
-
- 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同步修改后的遠程分支