SQL之谈谈事务和锁
ccwgpt 2024-11-25 10:22 66 浏览 0 评论
【十】事务和锁
10.1 事务具备的四个属性(简称ACID属性):
1)原子性(Atomicity):事务是一个完整的操作,事务的各步操作是不可分的(如原子不可分),操作要么都执行了,要么都不执行。
2)一致性(Consistency):事务执行的结果必须使数据库从一个一致的状态到另一个一致的状态。
3)隔离性(Isolation):事务的执行不干扰其他事务,一般来说数据库的隔离性都提供了不同程度的隔离级别。
4)持久性(Durability):事务一旦提交完成后,数据库就不可以丢失这个事务的结果,数据库通过日志能够保持事务的持久性。
10.2 事务的隔离级别:
10.2.1事务可能出现的三种隔离问题:
1.脏读:
脏读是指在一个事务中读到了另一个事务未提交的记录。
2.不可重复读:
在一个事务还没有结束时,读到了另一个事务更改(update)的并提交的记录,两次重复读到同一记录的不同值。
3.幻读:
在一个事务还没有结束时,读到了另一个事务更改(insert)的并提交的记录,第二次读到了新的记录,发生了幻觉一样。
10.2.2采用SQL标准中的四个隔离级别,可以针对性的解决脏读、不可重复读、幻读这三类问题。
10.3 事务的开始和结束:
10.3.1 事务采用隐性的方式
1)起始于session的第一条DML语句;
2)一个session某个时刻只能有一个事务。
10.3.2 事务结束的方式:
1)用户退出SQLPLUS(正常退出是提交,非正常退出是回滚);
2)服务器故障或系统崩溃(回滚);
3)shutdowm immediate(回滚)。
在一个事务里如果某个DML语句失败,之前其他任何DML语句将保持完好,且不会提交!
4)在事务所在的会话中做非DML操作,比如做DDL操作,默认的是提交。
10.4 Oracle的事务保存点功能:
savepoint命令允许在事务进行中设置一个标记(保存点),回滚到这个标记可以保留该点之前的事务存在,并使事务继续执行。
实验:
savepoint sp1;
delete from emp1 where empno=7900;
savepoint sp2;
update emp1 set ename='timran' where empno=7788;
select * from emp1;
rollback to sp2;
select * from emp1;
rollback to sp1;
注意rollback to XXX 后,XXX左侧的事务不会结束。
10.5 SCN的概念
10.5.1概念:
SCN全称是System Change Number,它是一个不断增长的整数,相当于Oracle内部的一个时钟,只要数据库一有变更,这个SCN就会增加,Oracle通过SCN记录数据库里事务的一致性。
SCN涉及了实例恢复和介质恢复的核心概念,它几乎无处不在:控制文件,数据文件,日志文件都有SCN,包括block上也有SCN。
10.5.2理解多版本读一致性
实际上,我们所说的保证同一时间点一致性读的概念,其背后是物理层面的block读,Oracle会依据你发出select命令,记录下那一刻的SCN值,然后以这个SCN值去同所读的每个block上的SCN比较,如果读到的块上的SCN大于select发出时记录的SCN,则需要利用Undo得到该block的前镜像,在内存中构造CR块(Consistent Read)。
10.5.3获得当前SCN的两个办法:
SQL> select current_scn from v$database;
SQL> select dbms_flashback.get_system_change_number from dual;
有两个函数可以实现SCN和TIMESTAMP之间的互转:
scn_to_timestamp / timestamp_to_scn
SQL> select scn_to_timestamp(current_scn) from v$database;
10.6 共享锁与排他锁的基本原理:
10.6.1 基本原则
排他锁:排斥其他的排他锁和共享锁;
共享锁:排斥其他的排他锁,不排斥其他的共享锁。
10.6.2 Oracle锁的种类
因为有事务才有锁的概念,Oracle数据库锁可以分为以下几大类:
DML锁(data locks,数据锁),用于保护数据的完整性;
DDL锁(dictionary locks,数据字典锁),用于保护数据库对象的结构,如表、索引等的结构定义;
SYSTEM锁(internal locks and latches),保护数据库的内部结构。
我们探讨Oracle的DML操作(insert、update、delete),它包括两种锁:TX(行锁)和TM(表锁)。
TX 是面向事务的行锁,它表示你锁定了表中的一行或若干行,update和delete操作都会产生行锁,insert操作除外。
TM 是面向对象的表锁,它表示你锁定了系统中的一个对象,在锁定期间不允许其他会话对这个对象做DDL操作。否则会报“ORA-00054: 资源正忙, 但指定以 NOWAIT 方式获取资源, 或者超时失效”。(ddl_lock_timeout参数可以延迟一段时间再该报错)。
行锁(TX)只有一种,表锁(TM)共有五种:分别是 RS, RX, S, SRX, X。对于DML操作,Oracle会自动加表级锁(即TM中的RX锁)和行锁(即TX锁)。
10.7 五种TM表锁的含义:
1)ROW SHARE 行共享 (RS)
允许其他用户同时更新其他行,允许其他用户同时加共享锁,不允许有独占(排他性质)的锁
2)ROW EXCLUSIVE 行排他 (RX)
允许其他用户同时更新其他行,只允许其他用户同时加行共享锁或者行排他锁
3)SHARE 共享 (S)
不允许其他用户同时更新任何行,只允许其他用户同时加共享锁或者行共享锁
4)SHARE ROW EXCLUSIVE共享行排他 (SRX)
不允许其他用户同时更新其他行,只允许其他用户同时加行共享锁
5)EXCLUSIVE排他 (X)
其他用户禁止更新任何行,禁止其他用户同时加任何排他锁。
10.8 加锁模式:
第一种方式:自动加锁
做DML操作时,如insert,update,delete,以及select....for update由oracle自动完成加锁
Session1/scott:
SQL> select * from dept1 where deptno=30 for update;
用for update加锁
Session2/sys:
SQL>select * from scott.dept1 for update;
不试探,被锁住
SSession2/sys:
SQL>select * from scott.dept1 for update nowait;
试探,以防被锁住
SQL>select * from scott.dept1 for update wait 5;
SQL> select * from scott.dept1 for update skip locked;
跳过加锁的记录,锁定其他记录
1)对整个表for update 是不锁insert语句的。
2)wait 5:等5秒自动退出;
nowait:不等待;
skip locked:跳过。
三个都可起到防止自己被挂起的作用。
【语法】:lock table 表名 in exclusive mode。(一般限于后三种表锁)
10.9 死锁和解锁:
Oracle自动侦测死锁,自动解决锁争用。
制作死锁案例:
session1
update scott.emp1 set sal=8000 where empno=7369;
session2
update scott.emp1 set sal=9000 where empno=7934;
session1
update scott.emp1 set sal=8000 where empno=7934;
session2
update scott.emp1 set sal=9000 where empno=7369;
报错:ORA-00060: 等待资源时检测到死锁
10.10 管理员如何解锁:
可以根据以下方法准确定位要kill session的sid号和serial#号:
SQL> select * from v$lock where type in ('TX','TM');
SQL> select a.sid,a.serial#,b.sql_text from v$session a,v$sql b where a.prev_sql_id=b.sql_id and a.sid=127;
SID SERIAL# SQL_TEXT
---------- ---------- --------------------------------------------------------------------------------
127 2449 update emp1 set sal=8000 where empno=7788
SQL> select sid,serial#,blocking_session,username,event from v$session where blocking_session_status='VALID';
SID SERIAL# BLOCKING_SESSION USERNAME EVENT
---------- ---------- ---------------- ------------------------------ ----------------------------------------
127 2449 134 SCOTT enq: TX - row lock contention
也可以根据v$lock视图的block 和request确定session阻塞关系,确定无误后再杀掉这个session
SQL>ALTER SYSTEM KILL SESSION '127,2449';
更详细的信息,可以从多个视图得出,相关的视图有:v$session, v$process, v$sql, v$locked, v$sqlarea等等…
阻塞(排队)从EM里看的更清楚 EM-->Performance-->Additional Monitoring Links-->Blocking Sessions(或Instance Locks)。
the end !!!
@jackman 共筑美好!
相关推荐
- 一个基于.Net Core遵循Clean Architecture原则开源架构
-
今天给大家推荐一个遵循CleanArchitecture原则开源架构。项目简介这是基于Asp.netCore6开发的,遵循CleanArchitecture原则,可以高效、快速地构建基于Ra...
- AI写代码翻车无数次,我发现只要提前做好这3步,bug立减80%
-
写十万行全是bug之后终于找到方法了开发"提示词管理助手"新版本那会儿,我差点被bug整崩溃。刚开始两周,全靠AI改代码架构,结果十万行程序漏洞百出。本来以为AI说没问题就稳了,结果...
- OneCode低代码平台的事件驱动设计:架构解析与实践
-
引言:低代码平台的事件驱动范式在现代软件开发中,事件驱动架构(EDA)已成为构建灵活、松耦合系统的核心范式。OneCode低代码平台通过创新性的注解驱动设计,将事件驱动理念深度融入平台架构,实现了业务...
- 国内大厂AI插件评测:根据UI图生成Vue前端代码
-
在IDEA中安装大厂的AI插件,打开ruoyi增强项目:yudao-ui-admin-vue31.CodeBuddy插件登录腾讯的CodeBuddy后,大模型选择deepseek-v3,输入提示语:...
- AI+低代码技术揭秘(二):核心架构
-
本文档介绍了为VTJ低代码平台提供支持的基本架构组件,包括Engine编排层、Provider服务系统、数据模型和代码生成管道。有关UI组件库和widget系统的信息,请参阅UI...
- GitDiagram用AI把代码库变成可视化架构图
-
这是一个名为gitdiagram的开源工具,可将GitHub仓库实时转换为交互式架构图,帮助开发者快速理解代码结构。核心功能一键可视化:替换GitHubURL中的"hub...
- 30天自制操作系统:第六天:代码架构整理与中断处理
-
1.拆开bootpack.c文件。根据设计模式将对应的功能封装成独立的文件。2.初始化pic:pic(可编程中断控制器):在设计上,cpu单独只能处理一个中断。而pic是将8个中断信号集合成一个中断...
- AI写代码越帮越忙?2025年研究揭露惊人真相
-
近年来,AI工具如雨后春笋般涌现,许多人开始幻想程序员的未来就是“对着AI说几句话”,就能轻松写出完美的代码。然而,2025年的一项最新研究却颠覆了这一期待,揭示了一个令人意外的结果。研究邀请了16位...
- 一键理解开源项目:两个自动生成GitHub代码架构图与说明书工具
-
一、GitDiagram可以一键生成github代码仓库的架构图如果想要可视化github开源项目:https://github.com/luler/reflex_ai_fast,也可以直接把域名替换...
- 5分钟掌握 c# 网络通讯架构及代码示例
-
以下是C#网络通讯架构的核心要点及代码示例,按协议类型分类整理:一、TCP协议(可靠连接)1.同步通信//服务器端usingSystem.Net.Sockets;usingTcpListene...
- 从复杂到优雅:用建造者和责任链重塑代码架构
-
引用设计模式是软件开发中的重要工具,它为解决常见问题提供了标准化的解决方案,提高了代码的可维护性和可扩展性,提升了开发效率,促进了团队协作,提高了软件质量,并帮助开发者更好地适应需求变化。通过学习和应...
- 低代码开发当道,我还需要学习LangChain这些框架吗?| IT杂谈
-
专注LLM深度应用,关注我不迷路前两天有位兄弟问了个问题:当然我很能理解这位朋友的担忧:期望效率最大化,时间用在刀刃上,“不要重新发明轮子”嘛。铺天盖地的AI信息轰炸与概念炒作,很容易让人浮躁与迷茫。...
- 框架设计并不是简单粗暴地写代码,而是要先弄清逻辑
-
3.框架设计3.框架设计本节我们要开发一个UI框架,底层以白鹭引擎为例。框架设计的第一步并不是直接撸代码,而是先想清楚设计思想,抽象。一个一个的UI窗口是独立的吗?不是的,...
- 大佬用 Avalonia 框架开发的 C# 代码 IDE
-
AvalonStudioAvalonStudio是一个开源的跨平台的开发编辑器(IDE),AvalonStudio的目标是成为一个功能齐全,并且可以让开发者快速使用的IDE,提高开发的生产力。A...
- 轻量级框架Lagent 仅需20行代码即可构建自己的智能代理
-
站长之家(ChinaZ.com)8月30日消息:Lagent是一个专注于基于LLM模型的代理开发的轻量级框架。它的设计旨在简化和提高这种模型下代理的开发效率。LLM模型是一种强大的工具,可以...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- 框架图 (58)
- flask框架 (53)
- quartz框架 (51)
- abp框架 (47)
- springmvc框架 (49)
- 分布式事务框架 (65)
- scrapy框架 (56)
- shiro框架 (61)
- 定时任务框架 (56)
- java日志框架 (61)
- mfc框架 (52)
- abb框架断路器 (48)
- beego框架 (52)
- java框架spring (58)
- grpc框架 (65)
- tornado框架 (48)
- 前端框架bootstrap (54)
- orm框架有哪些 (51)
- 知识框架图 (52)
- ppt框架 (55)
- 框架图模板 (59)
- 内联框架 (52)
- cad怎么画框架 (58)
- ssm框架实现登录注册 (49)
- oracle字符串长度 (48)