朝阳区网站建设,拉了专线可以直接做网站吗,成品网站w灬源码1688,国内前10电商代运营公司文章目录MySQL事务事务的四个特性 ACID事务提交的类型事务的使用MySQL事务
事务是什么#xff1f;
事务就是一组逻辑操作单元#xff0c;是数据从一种状态变成另外一种状态。整个单元有一个或多个SQL语句构成#xff0c;在这个操作单元中#xff0c;每一个SQL语句相互依赖…
文章目录MySQL事务事务的四个特性 ACID事务提交的类型事务的使用MySQL事务
事务是什么
事务就是一组逻辑操作单元是数据从一种状态变成另外一种状态。整个单元有一个或多个SQL语句构成在这个操作单元中每一个SQL语句相互依赖、不可分割是一个整体。
事务处理事务操作
保证所有的事务都作为一个工作单元来执行即使出现了故障都不要改变这种执行方式。但在一个事务中执行多个操作时要么整个事务被commit那样这些修改就会保存下来要么数据库管理系统将放弃所有的修改整个事务rollback到最初的状态
这个操作其实是为了确保数据的一致性这样不论这个被commit还是rollback都可以做到让数据库从一个一致性状态变换到另一个一致性状态。
事务的四个特性 ACID
事务是由一组SQL语句组成的逻辑处理单元它的ACID特性如下
原子性Atomicity原子性是指事务是一个不可分割的单位事务中的操作要么都发生要么都不发生。一致性Consistency事务必须使数据库从一个一致性状态变换到另外一个一致性状态。隔离性lsolation事务的隔离性是指多个用户并发访问数据库时数据库为每一个用户开启的事务不能被其他事务操作的数据所干扰多个并发事务之间要相互隔离。持久性Durability持久性是指一个事务一旦被commit他对数据库中数据的改变就是永久的接下的其他操作或故障不应对其有任何影响。 事务提交的类型 *隐式提交*即无需显示执行commit语句session中的操作被自动提交到数据库的过程。 *自动提交*若把AUTOCOMMIT设置为ON则在插入、修改、删除语句执行后 系统将自动进行提交这就是自动提交。 set autocommit on 显式提交用COMMIT命令直接完成的提交为显式提交。 commit
隐式提交的方式
正常执行完DDL语句。包括createalterdroptruncaterename。正常执行完DCL语句。包括grantrevoke。正常退出数据库管理软件没有明确发出commit或者rollback。
其实在执行DDL语句时前面的DML操作也会被提交到数据库中因为是在一个session里那执行ddl语句的时候前面的dml语句也会被提交到库中。即使DDL语句执行失败前面的DML操作也会被提交到数据库中
DDL都执行失败了怎么还会提交呢这就需要探究一下隐式提交的本质了为了避免隐式提交或者回滚尽量保证一条或者几条DML操作完成后有显示的提交或者回滚防止后续执行的DCL或者DDL自动提交前期的DML操作。
隐式提交的本质
一条DDL语句执行了两次commit
commit; —将当前session中未提交的事务隐式提交以保证DDL语句失败时的回滚位置
DDL statement;
commit; —将DDL操作提交
事务的使用
begin/start transaction开启事务编写事务中的sql语句commit rollback 结束事务提交或回滚