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

解决方案 »

  1.   

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

  2.   

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

  3.   

    补充程序说明一下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);  }
      

  4.   

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

  5.   

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

  6.   


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

  7.   

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