您的位置:首页技术文章
文章详情页

解决Oracle模拟事务提交、表锁,处理表锁问题

【字号: 日期:2023-03-12 15:25:14浏览:69作者:猪猪
目录
  • Oracle模拟事务提交、表锁,处理表锁问题
  • 1.查看AutoCommit
  • 2.手动提交事务流程
    • 2.1 终端一 尚未commit
    • 2.2 终端二 查询
    • 2.3 终端一 commit
    • 2.4 终端二 查询
  • 3.模拟表锁
    • 3.1 在终端一开启一个事务,但是不提交
    • 3.2 查询是否有表锁情况
    • 3.3 关闭该条未commit的事务

Oracle模拟事务提交、表锁,处理表锁问题

1.查看AutoCommit

# 我当前自动提交设置为OFF,即默认不自动提交SYS@helowin>show autocommit;autocommit OFF# 可通过set命令,选择是否开启自动提交事务SYS@helowin>set autoSP2-0281: autocommit missing set optionUsage: 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。看终端二中是否能看到插入的数据

2.1 终端一 尚未commit

# 在终端一模拟插入一条数据,不commitSYS@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_modefrom v$locked_object lo, dba_objects ao, v$session sesswhere ao.object_id = lo.object_idand lo.session_id = sess.sid;

3.3 关闭该条未commit的事务

alter system kill session "sid,serial#";

到此这篇关于Oracle模拟事务提交、表锁,处理表锁问题的文章就介绍到这了,更多相关Oracle处理表锁内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!

标签: Oracle