关于数据库事务的一些基础知识(转载)
来源:互联网 发布:国内三大文献数据库 编辑:程序博客网 时间:2024/05/29 12:30
- 原子性(Atomic):事务中各项操作,要么全做要么全不做,任何一项操作的失败都会导致整个事务的失败;
- 一致性(Consistent):事务结束后系统状态是一致的;
- 隔离性(Isolated):并发执行的事务彼此无法看到对方的中间状态;
- 持久性(Durable):事务完成后所做的改动都会被持久化,即使发生灾难性的失败。通过日志和同步备份可以在故障发生后重建数据。
补充:关于事务,在面试中被问到的概率是很高的,可以问的问题也是很多的。首先需要知道的是,只有存在并发数据访问时才需要事务。当多个事务访问同一数据时,可能会存在5类问题,包括3类数据读取问题(脏读、不可重复读和幻读)和2类数据更新问题(第1类丢失更新和第2类丢失更新)。
脏读(Dirty Read):A事务读取B事务尚未提交的数据并在此基础上操作,而B事务执行回滚,那么A读取到的数据就是脏数据。
不可重复读(Unrepeatable Read):事务A重新读取前面读取过的数据,发现该数据已经被另一个已提交的事务B修改过了。
幻读(Phantom Read):事务A重新执行一个查询,返回一系列符合查询条件的行,发现其中插入了被事务B提交的行。
第1类丢失更新:事务A撤销时,把已经提交的事务B的更新数据覆盖了。
第2类丢失更新:事务A覆盖事务B已经提交的数据,造成事务B所做的操作丢失。
数据并发访问所产生的问题,在有些场景下可能是允许的,但是有些场景下可能就是致命的,数据库通常会通过锁机制来解决数据并发访问问题,按锁定对象不同可以分为表级锁和行级锁;按并发事务锁定关系可以分为共享锁和独占锁,具体的内容大家可以自行查阅资料进行了解。
直接使用锁是非常麻烦的,为此数据库为用户提供了自动锁机制,只要用户指定会话的事务隔离级别,数据库就会通过分析SQL语句然后为事务访问的资源加上合适的锁,此外,数据库还会维护这些锁通过各种手段提高系统的性能,这些对用户来说都是透明的(就是说你不用理解,事实上我确实也不知道)。ANSI/ISO SQL 92标准定义了4个等级的事务隔离级别,如下表所示:
需要说明的是,事务隔离级别和数据访问的并发性是对立的,事务隔离级别越高并发性就越差。所以要根据具体的应用来确定合适的事务隔离级别,这个地方没有万能的原则。
- 关于数据库事务的一些基础知识(转载)
- [转载]关于数据库的一些基本知识
- (转载)数据库事务
- 数据库的一些基础知识
- 关于数据库的事务
- 事务隔离性的一些基础知识
- 关于事务的一些基本概念
- 关于事务的一些基本
- 关于事务的一些概念
- mysql数据库的一些基础知识
- Hbase数据库的一些基础知识
- 关于 XML 的一些基础知识
- 关于DNS的一些基础知识
- 一些关于Globus的基础知识
- 关于DNS的一些基础知识
- 一些关于Globus的基础知识
- 关于Eclipse的一些基础知识
- 关于一些基础知识的总结
- 虚拟化技术之KVM实战
- SuperMapXML文件解析
- Mongodb 干货
- 图片目录与TOMCAT根目录分离
- RxJava 源码解读分析 subscribeOn 方法
- 关于数据库事务的一些基础知识(转载)
- DeBug查看HttpServletQuest 传递的参数
- windows 安装git
- Web前端开发笔试题集锦之Javascript篇
- HOW-TO: upgrade nodejs to latest version
- Spring和SpringMVC区别
- Arraylist中封装类的结构
- RabbitMQ的几种典型使用场景
- Car