> 백엔드 개발 > PHP 튜토리얼 > 求问以下方法为何不能得到返回值?

求问以下方法为何不能得到返回值?

WBOY
풀어 주다: 2016-06-23 14:11:55
원래의
969명이 탐색했습니다.

本帖最后由 u010416883 于 2013-06-01 11:37:22 编辑

由解,以下疑问!
public static function query($sql, $unbuffered = false) {    $ret = self::$db->query($sql, $unbuffered);//该句成功时$ret为1  注::self::$db->query为mysql_query    if ($unbuffered===true) {      $cmd = trim(strtoupper(substr($sql, 0, strpos($sql, ' '))));      if ($cmd === 'SELECT') { }       elseif ($cmd === 'UPDATE' || $cmd === 'DELETE') {          $ret = self::$db->affected_rows();      }       elseif ($cmd === 'INSERT') {          $ret = self::$db->insert_id();//该处运行时证明执行了,返回的是int类型id号      }   }   return $ret;//最终返回不是int类型id号}       
로그인 후 복사


回复讨论(解决方案)

那你得到的是什么?

空字符串!!!!!

无论是否有后续操作,至少会返回 $ret = self::$db->query($sql, $unbuffered); 的值
既然是:该句成功时$ret为1,而你说返回为空,显然是查询失败了

$ret = self::$db->query($sql, $unbuffered); 这返回是1,看数据库数据也正常插入了,
并且下面的判断通过echo也返回了插入的的id,但最后的return返回的是空字符串

补充程序说明一下

self::$db->query($sql, $unbuffered);方法如下    public function query($sql, $unbuffered = false) {            $func = $unbuffered ? 'mysql_unbuffered_query' : 'mysql_query';            $query = $func($sql, $this->curlink);            $this->querynum++;            return $query;    }  self::$db->insert_id();方法如下function insert_id() {return ($id = mysql_insert_id($this->curlink)) >= 0 ? $id : @mysql_result($this->query("SELECT last_insert_id()"), false);  }
로그인 후 복사

由 public function query($sql, $unbuffered = false) { ... 可知
要么 query 返回资源,要么 query 返回逻辑值

你执行的sql是什么?执行query时,$unbuffered是什么?

由 public function query($sql, $unbuffered = false) { ... 可知
要么 query 返回资源,要么 query 返回逻辑值

这个是$ret = self::$db->query($sql, $unbuffered);
返回值echo为1,也说明sql执行成功!

你用elseif  如果某个条件断了下面的程序就不会再走

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