java事物的理解
来源:互联网 发布:python如何连接小票机 编辑:程序博客网 时间:2024/05/22 03:02
事务是并发控制的基本单元。所谓事务一个sql语句操作序列,这些操作要么都执行,要么都不执行,他是一个不可分割的工作单元。
例如:银行转账工作,从一个帐号扣款并使另一个帐号增款,这个两个操作,要么都执行,要么都不执行。
数据库的事务必须具备ACID特性,ACID是指 Atomic(原子性)、Consistensy(一致性)、Isolation(隔离型)和Durability(持久性)的英文缩写。
1、原子性(Atomicity)
一个事务中所有操作,要么全部完成,要么全部不完成,不会结束在中间某个环节。事务在执行过程中如果发生错误,会被回滚到事务开始前的状态,就像这个事务从来没有执行一样。
2、一致性(Consistency)
一个事务在执行之前和执行之后数据库都必须处于一致性状态。
如果事务成功的完成,那么数据库的所有变化将生效。
如果事务执行出现错误,那么数据库的所有变化将会被回滚(撤销),返回到原始状态。
举例1: a、b 转账 100
a - 100
b + 100
结果: a + b = 2000
举例2:公司部门 和 员工信息,前提是每个员工都有部门
需求:解散一个部门,
分析:删除一个部门 --》 导致员工找不到对应的部门 --》 造成员工的部门信息不一致
解决:应该先删除部门的员工,再删除部门, 保证数据的一致性
3、隔离性(Isolation)
多个用户并发的访问数据库时,一个用户的事务不能被其他用户的事务干扰,多个并发的事务之间要相互隔离。
多个事务事件是相互独立的,多个事务事件不能相互干扰。
a -b ----- 事务A
c -d ----- 事务B
如果A失败了,不能影响B。
4、持久性:
指一个事务一旦被提交,它对数据库的改变将是永久性的,接下来即使数据库发生故障也不会对数据产生影响。
举例:a、b转账
a-100
b+100
提交
结果: a 900 b 1100
开启事务
a - 100 出现错误 结果还是不变的。
- java事物的理解
- 对Java事物的理解
- 对Java事物的理解
- 对事物的理解
- 事物<一> JDBC事物的理解
- 对事物ACID的理解
- 转 hibernate事物的理解
- 对于数据库事物的理解
- MYSQL 中事物的理解
- 关于sql事物的理解
- spring 事物的一些理解
- java的事物的属性
- 数据库的事物隔离级别通俗理解
- 谈谈对于数据库事物的理解
- java 事物级别说明 事物注解的使用
- java 事物
- java事物
- JAVA事物
- 头文件AT89X51.H和reg52.h的区别
- unity载入dll void functionA(object o=null)
- Codeforces Round #409 div2 【A~D√ E待补】
- android使用WebView时添加error.html
- Fatal error: Can't use function return value in write context in
- java事物的理解
- PHP中关于Excel的使用
- Linux系统中crontab定时器设置
- es 数据 导出 到 MySQL
- Codeforces Round #319 (Div. 1)
- 如何配置sigar在Linux和Windows下使用java语言获得各种系统信息
- Google WomenTechmakers(北京区)感悟
- 因果图与判定表法
- 九度OJ题目1001:A+B for Matrices