事务是数据库中一个单独的执行单行(Unit),事务就是由一种数据操纵语言DML语句组成,这一组DML要么全不成功要么全部失败,是一个整体。 以网上购物为例,其交易过程包括以下几步:
在正常情况下,这些操作都将顺利执行,最终交易成功,与交易相关的所有数据库信息也成功地更新。但是,如果遇到断电或者是其他意外情况,导致这一系列过程中任何一个环节出了差错(例如在更新商品库存信息时发生异常、顾客银行账户余额不足等),都将导致整个交易过程失败。而一旦交易失败,数据库中所有信息都必须保持交易前的状态不变,例如最后一步更新用户信息时失败而导致交易失败,那么必须保证这笔失败的交易不影响数据库的状态,即原有的库存信息没有被更新,用户也没有付款,订单也没有生成。否则数据库的信息将会不一致,或者出现更为严重的不可预测的后果。
数据库事务正是用来拨正这种情况下交易的平稳性和可预测的技术。
开始一个事务:start transaction;
创建一个保存点:savepoint 保存点名;
回到保存点:rollback to 保存点
rollback
前提是事务还没有提交当我们有多个客户端同时操作数据库的某张表时,如何进行隔离操作?MySQL提供了隔离级别。当MySQL表被多个线程或者客户端开启各自事务操作数据库中的数据时,MySQL提供了一种机制,可以让不同的事务在操作数据时,具有隔离性。从而保证数据的一致性。
1、张三的原工资是1000,财务人员将张三的工资改为8000,但是未提交事务 2、张三读取自己的工资,发现是8000,欣喜若狂 3、财务发现操作有误,回滚了事务,张三的工资又变为1000 像这样,张三读取的工资数是8000就是一个脏数据
是指在一个事务内,多次读同一数据。在这个事务还没有结束时,另外一个事务也访问该同一数据。那么,在第一个事务中的两次读数据之间,由于第二个事务的修改,那么第一个事务两次读到的的数据可能是不一样的。这样就发生了在一个事务内两次读到的数据是不一样的,因此称为是不可重复读。(即不能读到相同的数据内容)
在事务1中,张三读取自己的工资为1000,操作并没有完成 在事务2中,财务将张三的工资改为2000,并提交了事务 在事务1中,张三再次读取自己的工资时,工资变为了2000 解决办法:如果只有在修改事务完全提交之后才可以读数据,则可以避免该问题
不可重复读的重点是修改:同样的条件, 你读取过的数据,再次读取出来发现值不一样了
是指当事务不是独立执行时发生的一种现象,例如第一个事务对一个表中的数据进行了修改,这种修改涉及到表中的全部数据行。同时,第二个事务也修改这个表中的数据,这种修改是向表中插入一行新数据。那么,第一个事务的用户发现表中还有没有修改的数据行,就好象发生了幻觉一样。
目前工资为1000的员工有10人 1、事务1,读取所有工资为1000的员工 2、事务2,向表中插入一条员工记录,工资为1000 3、事务1读取所有工资为1000的员工,读取了11条记录 解决办法:如果在操作事务完成数据处理之前,任何其他事务都不可以添加新数据,则可以避免该问题
幻读的重点在于新增或者删除:同样的条件, 第1次和第2次读出来的记录数不一样
set session transaction isolation level read uncommitted;
<< · Back Index ·>>
下一篇
哈喽,大家好,我是诗珑。 今天给大家分享的是一个可以免费下载PPT的网站——第一PPT。 网址:https://www.1ppt.com/ 第一PP ...
文 | 谢小楼 01 此诗一作《送灵澈上人》。灵澈(chè)上人:唐代著名僧人,上人是对僧人的敬称。 苍苍竹林寺,杳杳钟声晚。 ...