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⑵6
我们打开两个终端页面,先在终端一中摹拟插入一条数据,不履行commit。看终端二中会不会能看到插入的数据
2.1 终端一 还没有commit
# 在终端一摹拟插入一条数据,不commit
SYS@helowin>insert into zxy.study values(2,’b’,’2022-09⑵6′);
1 row created.
# 发现在当前终端中可以查到数据
# 在事务提交之前,只有操作数据库的这个人材能看到所做的事,他人只能等待提交后才可以
SYS@helowin>select * from zxy.study;
ID NAME TESTTIME
———- ——————– ————————————————–
2 b 2022-09⑵6
1 a 2022-09⑵6
2.2 终端二 查询
# 在终端二中不能查到数据
SYS@helowin>select * from zxy.study;
ID NAME TESTTIME
———- ——————– ————————————————–
1 a 2022-09⑵6
2.3 终端一 commit
SYS@helowin>commit;
Commit complete.
SYS@helowin>select * from zxy.study;
ID NAME TESTTIME
———- ——————– ————————————————–
2 b 2022-09⑵6
1 a 2022-09⑵6
2.4 终端二 查询
SYS@helowin>select * from zxy.study;
ID NAME TESTTIME
———- ——————– ————————————————–
2 b 2022-09⑵6
1 a 2022-09⑵6
3.摹拟表锁
开启事务,但是一直未提交,会造成表锁
3.1 在终端一开启一个事务,但是不提交
SYS@helowin>insert into zxy.study values(3,’c’,’2022-09⑵6′);
1 row created.
SYS@helowin>select * from zxy.study;
ID NAME TESTTIME
———- ——————– ————————————————–
2 b 2022-09⑵6
3 c 2022-09⑵6
1 a 2022-09⑵6
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#’;
到此这篇关于Oracle摹拟事务提交、表锁,处理表锁问题的文章就介绍到这了,更多相关Oracle处理表锁内容请搜索之前的文章或继续浏览下面的相关文章希望大家以后多多支持!
文章来源:丸子建站
文章标题:解决Oracle摹拟事务提交、表锁,处理表锁问题
https://www.wanzijz.com/view/60236.html