php mysql锁与事务_PHP编程中MySQL事务处理及锁定

中山电脑培训 中山职教电脑培训 PHP培训 中山PHP培训 中山职教PHP培训 PHP编程 招生 报名

在PHP编程中对MySQL事务处理及锁定的操作显得非常重要,然而事务的处理到底是一个怎样的机制,又是通过什么样的方式来完成的。众多的PHP编程人员都知道,在PHP编程中事务处理(Transaction)是将多个更新命令作为一个整体来执行,从而保证数据整合性的机制。

在PHP编程中,存储引擎(Storage Engine)对于PHP程序员来说并不陌生;MySQL 有一个重要特征,即:可替换存储引擎构架(Pluggable Storage Engine Architecture)MySQL 的功能分为2个部分:第一是外层部分:负责完成与客户端的连接、对 SQL 语句进行事前检查等。第二是内层部分:存储引擎部分,负责接收外层的数据操作指示,完成实际的数据输入输出以及文件操作。

作为长期开发的编程人员都知道MySQL提供了多种存储引擎,用户可自由选择(也可以给不同的表,选择不同的存储引擎)用户可以任意选择存储引擎,这是 MySQL 独有的特征,以下是对MYSQL的一些独有的特征进行介绍。

首先这些MYSQL独有的特征是PHP编程人员所必须懂得的,而且是经常在程序开发过程中所要解决的;(一):MyISAM :默认的高速引擎,不支持事务处理;(二):InnoDB :支持行锁定,以及事务处理,比 MyISAM 的处理速度稍慢;(三):ISAM :MyISAM 引擎的前身。MySQL 5.0 以后,不再标准安装;(四)MERGE : 该引擎,会将多个 MyISAM 类型的表,作为一个表来处理,(五)MEMORY, HEAP : 只在内存上保存数据,(六)Falcon :一种新的存储引擎,支持事务处理;(七)ARCHIVE: 将数据压缩后保存 (只能进行 INSERT / SELECT 操作);(八)CSV : 以CSV 形式保存数据(应用于跨平台数据交换);(九)my.ini 中, 设置:default-storage-engine=INNODB才能使用 InnoDB 引擎,来支持事务处理;(十)[sql] SHOW CREATE TABLE customer;  SHOW CREATE TABLE customerG  [sql] ALTER TABLE customer ENGINE=MyISAM.

在PHP编程,以及网站开发的过程中,我们PHP程序员要清楚的知道为什么需要事务处理?例如:甲,向乙转账1 万元。需要2个操作,甲的账户减少 1万,乙的账户增加 1万。如果,甲账户减少 1万之后,乙账户却没有相应增加1万,则发生错误。为避免此类情况,将2个操作作为一个事务来处理,2个操作都成功,则事务结束,进行提交(COMMIT)。如果 其中1个操作失败,则强制返回最初的状态,即:回滚(ROLLBACK)这样,能保证,要么2个操作都成功,要么2个操作都失败。多用户同时读取数据库时候,为防止冲突,可使用锁定(Lock)、解锁(Unlock)锁定分为:共享锁定(Shared Lock)、排他锁定(eXclusive Lock)共享锁定,有时也称为,读取锁定。当用户参照数据时,将对象数据变为只读形式。排他锁定,也称为,写入锁定 或 独占锁定。在执行 INSERT、UPDATE、DELETE 等操作时,使用该锁定。其他进程、事务,一律不能读取、更新、写入。

锁定粒度:记录(行)、表、数据库。锁定提升机制:当行单位粒度的锁定,大量产生时,数据库将锁定粒度自动向上提升(比如,提升成表粒度的锁定,或者数据库粒度的锁定)分离水平:事务处理之间的影响程度(同时运行时互相影响的机制)分离水平有 4 种: READ UNCOMMITTED :支持, 非提交读取、不可重复读取、幻象读取READ COMMITTED :支持,不可重复读取、幻象读取REPEATABLE READ :支持,幻象读取SERIALIZABLE :都不支持非提交读取(脏读 Dirty Read):能从别的事务处理中,读取到尚未提交的更新数据,只发生在 READ UNCOMMITTED 分离水平。不推荐使用[sql] SET SESSION TRANSACTION ISOLATION LEVEL READ UNCOMMITTED;  不可重复读取(Non-Repeatable Read):某一事务处理中,由于其他事务处理的更新操作,导致,对同一数据的多次读取,结果不同。发生在 READ COMMITED 以下的分离水平幻象读取(Phantom Read):某一事务处理中,对同一数据进行多次读取时,由于其他事务处理的插入、删除操作,使得结果中,出现了第一读取时,不存在的数据,或者,第一次读取时,存在的数据消失了,的现象。死锁(Dead Lock)两个不同的事务处理,在相互等待对方释放锁定,永远也不可能解除锁定的一种状态。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值