您现在的位置是:网站首页> 编程资料编程资料
解决Oracle模拟事务提交、表锁,处理表锁问题_oracle_
2023-05-27
460人已围观
简介 解决Oracle模拟事务提交、表锁,处理表锁问题_oracle_
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。看终端二中是否能看到插入的数据
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#';

到此这篇关于Oracle模拟事务提交、表锁,处理表锁问题的文章就介绍到这了,更多相关Oracle处理表锁内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
您可能感兴趣的文章:
相关内容
- Oracle 删除大量表记录操作分析总结_oracle_
- Oracle如何在SQL语句中对时间操作、运算_oracle_
- ORACLE中常用的几种正则表达式小结_oracle_
- Oracle创建用户与表空间的绝对干货(建议收藏)_oracle_
- sql查询给表起别名要点小结(涉及嵌套查询)_oracle_
- 一文解析ORACLE树结构查询_oracle_
- SQL案例学习之字符串的合并与拆分方法总结_oracle_
- Oracle根据时间查询的一些常见情况汇总_oracle_
- mybatis 调用 Oracle 存储过程并接受返回值的示例代码_oracle_
- ORACLE ORA-01653: unable to extend table 的错误处理方案(oracle报错)_oracle_
