Oracle 数据库使用事务确保数据的安全

使用事务是为了保证数据的安全有效。

事务的特点

事务有一下四个特点:(ACID)

原子性(Atomic):事务中所有数据的修改,要么全部执行,要么全部不执行。

一致性(Consistence):事务完成时,要使所有所有的数据都保持一致的状态,换言之:通过事 务进行的所有数据修改,必须在所有相关的表中得到反映。

隔离性(Isolation):事务应该在另一个事务对数据的修改前或者修改后进行访问。

持久性(Durability):保证事务对数据库的修改是持久有效的,即使发生系统故障,也不应该丢失。

事务的隔离级别

▲ Oracle 默认的隔离级别是 read committed。

▲ Oracle 支持上述四种隔离级别中的两种:read committed 和 serializable。除此之外, Oralce 中还定义 Read only 和 Read write 隔离级别。

▲ Read only:事务中不能有任何修改数据库中数据的操作语句,是 Serializable 的一个子集。

▲ Read write:它是默认设置,该选项表示在事务中可以有访问语句、修改语句,但不经常使用。

**丢失更新:**两个事务同时存储, 一个存储 100 , 一个存储 200,最终可能至存储了 200 或者 100,那 另一个的更新就没成功,即结果不为预想的 300

**脏读:**事务 T1 更新了一行数据,还没有提交所做的修改,T2 读取更新后的数据,T1回滚,T2 读取的数 据无效,这种数据称为脏读数据。

**不可重复读:**事务 T1 读取一行数据,T2 修改了 T1 刚刚读取的记录,T1 再次查询,发现与第一次读取 的记录不相同,称为不可重复读。

**幻读:**事务 T1 读取一条带 WHERE 条件的语句,返回结果集,T2 插入一条新纪录,恰好也是 T1 的 WHERE 条件,T1 再次查询,结果集中又看到 T2 的记录,新纪录就叫做幻读。

事务的开启

自动开启于 DML 之 insert delete update

事务的结束

成功

正常执行完成的 DDL 语句:create、alter、drop

正常执行完 DCL 语句 GRANT、REVOKE

正常退出的 SQLPlus 或者 SQL Developer 等客户端如果人工要使用隐式事务,SET AUTOCOMMIT ON (只针对一个连接)

手动提交 :使用 commit

失败

rollback ,手动回滚

非法退出 意外的断电

**注意:**rollback 只能对未提交的数据撤销,已经 Commit 的数据是无法撤销的,因为 commit 之后已经持久化 到数据库中。

今天的内容就学习到这里了,每个工作日小编都会更新一个有关测试的小知识,希望大家多多关注我们,一起来学习喔!

相关推荐
叫我:松哥17 分钟前
基于Python的共享单车租赁数据分析与预测系统,技术栈flask+boostrap+随机森林+XGBoost
人工智能·python·深度学习·算法·随机森林·数据分析·flask
Li#26 分钟前
web端电商项目自动下单发货评价晒图需要用到的能力
python·自动化
BAGAE29 分钟前
星链卫星数据获取:从太空安全到实时通信的技术革命
网络·数据结构·数据库·算法·云计算·hbase
zh_xuan32 分钟前
Android导出并查看数据库
数据库·sqlite
加加and减减33 分钟前
Docker真实安装mysql8教程并优化配置
运维·mysql·docker·容器
小短腿的代码世界42 分钟前
Qt定时器高精度架构:从QTimer源码到纳秒级定时调度
数据库·qt·架构
雨辰AI1 小时前
从零搭建大模型本地运行环境|Python+CUDA 基础配置避坑大全
大数据·开发语言·人工智能·python·ai·ai编程·ai写作
herinspace1 小时前
管家婆辉煌软件如何新增往来单位档案分类
服务器·数据库·电脑·管家婆软件
程序猿乐锅1 小时前
【MySQL | 第九篇】MySQL 存储过程
数据库·mysql
DogDaoDao1 小时前
【第 05 篇】Python的字典与集合
开发语言·python·集合·字典