今天有同事碰到一个问题,说是开事务了,然后在中间有个地方因为代码的原因中断了,结果数据库就堵在哪里了。
一、首先,同事说是因为中间代码有错误,就会停止执行。于是我写了一段代码
20 try{ 21 $a = $b; 22 $c = $a; 23 echo "c=$c\n"; 24 25 } 26 catch(Exception $e){ 27 echo "exception caught".$e->getMessage()."\n"; 28 } 29 echo "done\n";
发现上面的代码是能一直执行下去的,就开始怀疑同事的说法,觉得php是解释型语言,碰到错误就直接忽略,继续执行
后来,同事在里面加了一行代码
$aa::a();
立马执行不了了
比较了这两个程序,发现一个是语法错误,另一个是运行时错误,就像难道php会先进行语法检查,看了下php的执行过程,确实,php脚本先由zend引擎编译成opcode序列,这个过程中如果有语法错误,是不会进行编译的。这里有个问题,错误处理函数能捕获到到语法错误不?
于是就想php有哪些语法错误:查了下,常见的大概有这么几种
Parse error: parse error, expecting 1、变量没加$号 2、缺少;号 3、(,)不匹配
4、“”,‘’不匹配
这个是===================== $num=$this->ExecuteQuery("DELETE FROM resultlist WHERE ID=".$ID); if($num==1) return TRUE; else return FALSE; 如果你的源代码被出来,要么你的php环境没搭好,要么你用了<? ?>,要是后都的话,请改为<?php ?>即可.
没整明白===================
二、事务为啥没有回滚捏
事务开启之后,客户端一开始与服务器交互,加了一堆锁,然后突然挂掉了,服务器一直在等待客户端发commit或rollback命令,一直到链接超时,才会自动回滚
结论:语法错误,必须人工保证,而运行时错误,php会继续继续执行,如果开启了事务,尤其是全局事务,要特别小心,如果出现语法错误(代码质量够差的,联调、测试的时候可能出现),或者线上代码不小心被人覆盖代码(这个还是有一定的可能的),那就悲剧了,所以若非必要,还是要避免全局事务,代码质量真的很重要
|