>  기사  >  백엔드 개발  >  为什么mysql事务执行不了?解决办法

为什么mysql事务执行不了?解决办法

WBOY
WBOY원래의
2016-06-13 10:17:17974검색

为什么mysql事务执行不了?
php代码片断:  

/*-----数据库连接参数--*/  

$host="localhost";  

$user="root";  

$pwd="xxx";  

$database="luntan";  

/*-----数据库连接-*/  

$db=mysql_connect($host,$user,$pwd);  

$sql="START TRANSACTION;  

  SELECT @A:=MAX(iTopicId) FROM lun_topic;  

  INSERT INTO lun_topic VALUES(@A+1,'主题','内容','作者',NOW(),1);  

  COMMIT;";  

$result=mysql_db_query($database,$sql);//该句执行不了,也不报错  

   

  

表lun_topic  

iTopicId,  

vTitle,  

txtMessage,  

vPostId,  

dPostDateTime,  

iAreaId  

  

---------------------------  

  

注意在MySql中,只有INNODB和BDB类型的表支持事务处理,而缺省的MYISAM类型不支持,可以在创建表的时候指定表类型  

CREATE TABLE t (i INT) TYPE = INNODB;  

  

也可以转换已存在表的表类型  

ALTER TABLE t TYPE=INNODB  

---------------------------  


------解决方案--------------------
你的 $sql 要分作 4 句执行

php 的 mysql 函数,除了定义存储过程外,一次只能执行一条 sql 指令

说的不严密,其实定义存储过程也只是一条指令
------解决方案--------------------
php 的 mysql 函数,除了定义存储过程外,一次只能执行一条 sql 指令

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.