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

PHP中文网
發布: 2023-02-28 13:24:01
原創
941 人瀏覽過

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

由解,以下疑问!

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,而你说返回为空,显然是查询失败了
------解决方案--------------------
由 public function query($sql, $unbuffered = false) { ... 可知
要么 query 返回资源,要么 query 返回逻辑值
------解决方案--------------------
你执行的sql是什么?执行query时,$unbuffered是什么?
------解决方案--------------------
你用elseif  如果某个条件断了下面的程序就不会再走

 以上就是求问以下方法为何不能得到返回值的内容,更多相关内容请关注PHP中文网(m.sbmmt.com)!


相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!