AutoCAD 3DMAX C语言 Pro/E UG JAVA编程 PHP编程 Maya动画 Matlab应用 Android
Photoshop Word Excel flash VB编程 VC编程 Coreldraw SolidWorks A Designer Unity3D
 首页 > MySQL

PHP与MYSQL事务处理

51自学网 http://www.wanshiok.com
以下是InnoDB和MyISAM的一些联系和区别! 

1. 4.0以上mysqld都支持事务,包括非max版本。3.23的需要max版本mysqld才能支持事务。 

2. 创建表时如果不指定type则默认为myisam,不支持事务。 
可以用 show create table tablename 命令看表的类型。 

2.1 对不支持事务的表做start/commit操作没有任何效果,在执行commit前已经提交,测试: 
执行一个msyql: 
use test; 
drop table if exists tn; 
create table tn (a varchar(10)) type=myisam; 
drop table if exists ty; 
create table ty (a varchar(10)) type=innodb; 

begin; 
insert into tn values(‘a’); 
insert into ty values(‘a’); 
select * from tn; 
select * from ty; 
都能看到一条记录 

执行另一个mysql: 
use test; 
select * from tn; 
select * from ty; 
只有tn能看到一条记录 
然后在另一边 
commit; 
才都能看到记录。 

3. 可以执行以下命令来切换非事务表到事务(数据不会丢失),innodb表比myisam表更安全: 
   alter table tablename type=innodb; 

3.1 innodb表不能用repair table命令和myisamchk -r table_name 
但可以用check table,以及mysqlcheck [OPTIONS] database [tables] 

============================================================== 

mysql中使用select for update的必须针对InnoDb,并且是在一个事务中,才能起作用。 

select的条件不一样,采用的是行级锁还是表级锁也不一样。 
转http://www.neo.com.tw/archives/900 的说明 

由于InnoDB 预设是Row-Level Lock,所以只有「明确」的指定主键,MySQL 才会执行Row lock (只锁住被选取的资料例) ,
否则MySQL 将会执行Table Lock (将整个资料表单给锁住)。 


举个例子: 

假设有个表单products ,里面有id 跟name 二个栏位,id 是主键。 

例1: (明确指定主键,并且有此笔资料,row lock) 

SELECT * FROM products WHERE id=’3′ FOR UPDATE; 

例2: (明确指定主键,若查无此笔资料,无lock) 

SELECT * FROM products WHERE id=’-1′ FOR UPDATE; 

例2: (无主键,table lock) 

SELECT * FROM products WHERE name=’Mouse’ FOR UPDATE; 

例3: (主键不明确,table lock) 

SELECT * FROM products WHERE id<>’3′ FOR UPDATE; 

例4: (主键不明确,table lock) 

SELECT * FROM products WHERE id LIKE ’3′ FOR UPDATE; 

注1: 
FOR UPDATE 仅适用于InnoDB,且必须在交易区块(BEGIN/COMMIT)中才能生效

 
上一篇:简单整理MySQL的日志操作命令  下一篇:mysql 表索引的一些要点