> 백엔드 개발 > PHP 튜토리얼 > php事务处理后怎的进行页面跳转

php事务处理后怎的进行页面跳转

WBOY
풀어 주다: 2016-06-13 13:06:58
원래의
756명이 탐색했습니다.

php事务处理后怎样进行页面跳转

我用的是smarty模板,中间需要一个事务处理,同时想数据库插入两条数据,而且必须是成功都成功,失败都失败。

开始我用的是mysql_query('begin');

????????????????? mysql_query($sql);

????????????????? mysql_query($sql);

然后一个if判断,都为true的话commit,否则rollback。最后

????????????????? mysql_query('end');

但是在end之后我要进行一个php页面的跳转,加上end后,end以后的php代码都不执行了,数据添加成功与否页面都不尽兴跳转了。

?

?

?

然后我用set autocommit??? ,把自动提交设置成手动,但是和上边情况一样。。。

?

?

后来我写了一个方法,定义一个全局变量想通过全局变量来判断是否成功,但是这个全局变量的值在方法中确实被改变了,但在方法结束后这个值没有传出来,在外边用var_dump($tranResult),一直都是一个空白的值。。。。。。

?

??? function tranType1($type,$product_name,$pic_name,$name,$diameter,$capacity,$pic){
??? ???? ??? global $tranResult;
??? ???? ???
??? ???? ??? $this->db->query('begin');
??? ???? ??? $main_id = $this->addInfoTable1($type,$product_name,$pic_name);?? //这两个是我写的添加信息的方法,返回的是mysql_insert_id()
??? ???? ??? $addTab2 = $this->addInfoTub($main_id,$name,$diameter,$capacity);
??? ???? ??? if(($main_id !== false) && ($addTab2 !== false) ){
??? ??? ??? ??? $upPic = $this->comm->checkPic($pic);
??? ??? ??? ??? if($upPic){ ???
??? ??? ??? ??? ? $this->db->query('commit');??? ??? ??? ???
??? ??? ??? ??? ? $tranResult = true;
??? ??? ??? ??? ? //var_dump($tranResult);
??? ??? ??? ??? }else{
??? ??? ??? ??? ? $this->db->query('rollback');
??? ??? ??? ??? }
??? ??? ??? }else{
??? ??? ??? ??? ?$this->db->query('rollback');
??? ??? ??? }
??? ??? ???
??? ??? ??? $this->db->query('end');
??? ??? ??? var_dump($tranResult);
??? ?}

?

?

?

?

?

小弟实在想不出解决的方案了,请各位大侠来帮忙解决一下,万分感谢!!!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿