数据库事务的处理方式
数据库事务是一个逻辑上的划分,有的时候并不是很明显,它可以是一个操作步骤也可以是多个操作步骤。我们可以这样理解数据库事物:对数据库所做的一系列修改,在修改过程中,暂时不写入数据库,而是缓存起来,用户在自己的终端可以预览变化,直到全部修改完成,并经过检查确认无误后,一次性提交并写入数据库,在提交之前,必要的话所做的修改都可以取消。提交之后,就不能撤销,提交成功后其他用户才可以通过查询浏览数据的变化。
1、性质(ACID)
原子性(Atomicity):事务中的全部操作在数据库中是不可分割的,要么全部完成,要么全部不执行。
一致性(Consistency):几个并行执行的事务,其执行结果必须与按某一顺序 串行执行的结果相一致。
隔离性(Isolation):事务的执行不受其他事务的干扰,事务执行的中间结果对其他事务必须是透明的。
持久性(Durability):对于任意已提交事务,系统必须保证该事务对数据库的改变不被丢失,即使数据库出现故障。
2、作用
为数据库操作序列提供了一个从失败中恢复到正常状态的方法,同时提供了数据库即使在异常状态下仍能保持一致性的方法。
当多个应用程序在并发访问数据库时,可以在这些应用程序之间提供一个隔离方法,以防止彼此的操作互相干扰。
3、数据库事务处理相关命令
查看存储引擎 SHOW CREATE TABLE 表名;
更改引擎 ALTER TABLE 表名 ENGINE=新引擎名;
回滚 ROLLBACK;
声明事务开始 BEIGIN;
事务提交 COMMIT;
查询自动提交功能状态 SELECT @@AUTOCOMMIT;
设置自动提交功能 SET AUTOCOMMIT=0或1;
设置分离水平 SET SESSION TRANSACTION ISOLATION LEVEL 分离水平;