php做网站安性如何,福州网站建设电话,临沂医院网站建设,上海原画培训机构排名以下的文章主要向大家描述的是MySQL数据库和相关事务#xff0c;在实际操作中有很多人都认为MySQL数据库对事务处理是不支持的#xff0c;其实#xff0c;只要MySQL数据库版本支持BDB或是InnoDB表类型#xff0c;那么你的MySQL就具有事务处理的能力。这里面#xff0c;又以…以下的文章主要向大家描述的是MySQL数据库和相关事务在实际操作中有很多人都认为MySQL数据库对事务处理是不支持的其实只要MySQL数据库版本支持BDB或是InnoDB表类型那么你的MySQL就具有事务处理的能力。这里面又以InnoDB表类型用的最多虽然后来发生了诸如Oracle收购InnoDB等令MySQL不爽的事情但那些商业上的斗争与技术无关下面以InnoDB表类型为例简单说一下MySQL中的事务。先来明确一下事务涉及的相关知识事务都应该具备ACID特征。所谓ACID是Atomic(原子性)Consistent(一致性)Isolated(隔离性)Durable(持续性)四个词的首字母所写下面以“银行转帐”为例来分别说明一下它们的含义原子性组成事务处理的语句形成了一个逻辑单元不能只执行其中的一部分。换句话说事务是不可分割的最小单元。比如银行转帐过程中必须同时从一个帐户减去转帐金额并加到另一个帐户中只改变一个帐户是不合理的。一致性在事务处理执行前后MySQL数据库是一致的。也就是说事务应该正确的转换系统状态。比如银行转帐过程中要么转帐金额从一个帐户转入另一个帐户要么两个帐户都不变没有其他的情况。隔离性一个事务处理对另一个事务处理没有影响。就是说任何事务都不可能看到一个处在不完整状态下的事务。比如说银行转帐过程中在转帐事务没有提交之前另一个转帐事务只能处于等待状态。持续性事务处理的效果能够被***保存下来。反过来说事务应当能够承受所有的失败包括服务器、进程、通信以及媒体失败等等。比如银行转帐过程中转帐后帐户的状态要能被保存下来。再来看看哪些问题会用到事务处理这里不说“银行转帐”的例子了说一个大家实际更容易遇到的“网上购书”的例子。先假设一下问题的背景网上购书某书(MySQL数据库编号为123)只剩***一本而这个时候两个用户对这本书几乎同时发出了购买请求让我们看看整个过程在具体分析之前先来看看数据表的定义create table book(book_id unsigned int(10) not null auto_increment,book_name varchar(100) not null,book_price float(5, 2) not null, #我假设每本书的价格不会超过999.99元book_number int(10) not null,primary key (book_id))typeinnodb; #engineinnodb也行对于用户甲来说他的动作稍微比乙快一点点其购买过程所触发的动作大致是这样的1. SELECT book_number FROM book WHERE book_id 123;book_number大于零确认购买行为并更新book_number2. UPDATE book SET book_number book_number - 1 WHERE book_id 123;购书成功而对于用户乙来说他的动作稍微比甲慢一点点其购买过程所触发的动作和甲相同1. SELECT book_number FROM book WHERE book_id 123;这个时候甲刚刚进行完***步的操作还没来得及做第二步操作所以book_number一定大于零2. UPDATE book SET book_number book_number - 1 WHERE book_id 123;购书成功表面上看甲乙的操作都成功了他们都买到了书但是库存只有一本他们怎么可能都成功呢再看看数据表里book_number的内容已经变成“-1”了这当然是不能允许的(实际上声明这样的列类型应该加上unsigned的属性以保证其不能为负这里是为了说明问题所以没有这样设置)好了问题陈述清楚了再来看看怎么利用事务来解决这个问题打开MySQL手册可以看到想用事务来保护你的SQL正确执行其实很简单基本就是三个语句开始提交回滚。开始START TRANSACTION或BEGIN语句可以开始一项新的事务提交COMMIT可以提交当前事务是变更成为***变更回滚ROLLBACK可以回滚当前事务取消其变更此外SET AUTOCOMMIT {0 | 1}可以禁用或启用默认的autocommit模式用于当前连接。那是不是只要用事务语句包一下我们的SQL语句就能保证正确了呢比如下面代码BEGIN;SELECT book_number FROM book WHEREbook_id123;// ...UPDATE book SETbook_numberbook_number book_number - 1 WHEREbook_id123;COMMIT;答案是否定了这样依然不能避免问题的发生如果想避免这样的情况实际应该如下BEGIN;SELECT book_number FROM book WHEREbook_id123FOR UPDATE;// ...UPDATE book SETbook_numberbook_number book_number - 1 WHEREbook_id123;COMMIT;由于加入了FOR UPDATE所以会在此条记录上加上一个行锁如果此事务没有完全结束那么其他的事务在使用SELECT ... FOR UPDATE请求的时候就会处于等待状态直到上一个事务结束它才能继续从而避免了问题的发生需要注意的是如果你其他的事务使用的是不带FOR UPDATE的SELECT语句将得不到这种保护。以上的相关内容就是对MySQL数据库与事务的介绍望你能有所收获。【编辑推荐】【责任编辑孙巧华 TEL(010)68476606】点赞 0