后台(19)——事务Transaction
发布日期:2021-06-30 11:17:52
浏览次数:2
分类:技术文章
本文共 1295 字,大约阅读时间需要 4 分钟。
版权声明
- 本文原创作者:
- 作者博客地址:
事务简介
事务(Transaction)是数据库操作中并发控制的基本单位。事务是一个操作序列,这个序列中的所有数据库操作要么都成功执行,要么都不执行,它是一个不可分割的工作单位。
在数据库中与事务相关的操作有:
- 开启事务:start transaction
- 提交事务:commit
- 回滚事务:rollback
事务的特性
原子性
事务是一个不可分割的工作单位,事务中的操作要么都发生,要么都不发生。一致性
事务必须使数据库从一个一致性状态变换到另外一个一致性状态。比如:两个账户相互转账,那么转账前和转账后的总金额不变。隔离性
多个用户并发访问数据库时,数据库为每一个用户开启的事务不能被其他事务的操作数据所干扰;即多个并发事务之间要相互隔离。持久性
事务一旦被提交,它对数据库中数据的改变就是永久性的,即使数据库发生故障也不应该对其有任何影响
事务的四大特性中原子性,一致性,持久性很好理解,在此不再赘述。
下面重点介绍一下事务的隔离级别。
在多个线程中各自开启事务操作数据库中数据时,数据库系统要负责隔离操作,以保证各个线程在获取数据时的准确性。假如,事务不考虑隔离性可能会引发如下问题:赃读
在一个事务中读取了另一个事务未提交的数据。不可重复读
在一个事务内读取表中的某些数据,多次读取结果不同;即一个事务读取到了另一个事务提交后的数据。比如:开启事务后利用SQL语句查询数据,得到结果;立即再次查询得到的结果却与刚才不一样。通俗地说,不可重复读就是:自己的事务还没有提交,又读到了其它事务中执行了upate并提交的数据。虚读
是指在一个事务内读取到了别的事务中执行insert并提交的数据,导致前后读取不一致。
数据库通过设置事务的隔离级别防止以上情况的发生,常用的事务级别有如下几种:
1、READ UNCOMMITTED
将事务级别设置为该级别后,赃读、不可重复读、虚读都有可能发生。2、READ COMMITTED
将事务级别设置为该级别后,可避免赃读;但是不可重复读、虚读都有可能发生3、REPEATABLE READ
将事务级别设置为该级别后,避免赃读、不可重复读;但是虚读有可能发生。4、SERIALIZABLE
将事务级别设置为该级别后,可避免赃读、不可重复读以及虚读。
关于数据库的事务级别,请注意:
- 事务级别越高那么数据操作越安全但是操作性能越低
- 在MySQL中可利用SELECT @@TX_ISOLATION查看当前的事务隔离级别
- 在MySQL中可利用SET TRANSACTION ISOLATION LEVEL XXXXX 更改事务隔离级别
- 应在开启事务之前设置隔离级别
JDBC中控制事务以及操作事务
- 利用connection.setTransactionIsolation(int level)设置隔离级别
- 利用connection.setAutoCommit(false)开启事务
- 利用connection.commit( )提交事务
- 利用connection.rollback( )回滚事务
转载地址:https://it9527.blog.csdn.net/article/details/55522293 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!
发表评论
最新留言
初次前来,多多关照!
[***.217.46.12]2024年04月13日 22时16分24秒
关于作者
喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
OpenStack入门及原理基础理论知识点
2021-07-03
openstack的keystone认证服务
2021-07-03
OpenStack架构搭建实战(命令可复制)
2021-07-03
openstack的glance镜像服务
2021-07-03
Linux网络知识---网络配置
2021-07-03
openstack的Nova计算服务
2021-07-03
Linux的常用基础命令
2021-07-03
Linux操作系统的引导过程和排除启动故障
2021-07-03
自动化运维必备——ansible中playbook的编写
2019-04-30
自动化运维必备!ansible的安装及常用模块详解
2019-04-30
Error!启动elasticsearch报错
2019-04-30
CentOS7安装freeSwith1.6
2019-04-30
FreeSWITCH使用MySQL数据库
2019-04-30
Linux自动清理缓和Linux自动清理缓存不起作用原因(亲测有效)
2019-04-30
EasyPol-1
2019-04-30
springboot定时器的使用
2019-04-30
JavaScript原生开关灯效果
2019-04-30
企业邮箱如何申请注册,邮箱申请如何免费注册?
2019-04-30