好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

mode must be an integer,该如何解决?

今天在写自定义mvc框架的时候遇到一个问题:

SQLSTATE[HY000]: General error: mode must be an integer

下面贴上代码:

//这是报错位置的代码
public function dao_query($sql,$all = true){
   try{
  $stmt = $this->pdo->query($sql);

  //设置fetch_mode
  
  
   $stmt->setFetchMode($this->fetch_mode);//这里报错
  //解析数据
  if(!$all){
 return $stmt->fetch();
   }else{
 return $stmt->fetchAll();
}
  }catch(PDOException $e){
  $this->dao_exception($e);
   }
    }

代码提示:General error: mode must be an integer,我又去翻了一下文档

PDOStatement::fetchAll([ int $fetch_style [, mixed $fetch_argument   [, array $ctor_args = array()  ]]] ) : array

这里标注 $fetch_style 必须为 int 型,后来我直接将 $this->fetch_mode 直接改成 PDO::FETCH_ASSOC ,发现运行成功,后来翻到我的 config 里面存储的竟然是个字符串类型:

'database'=>array(
    'type'=>'mysql',
    'host'=>'localhost',
    'port'=>'3306',
    'user'=>'root',
    'pass'=>'root',
    'charset'=>'utf8',
    'dbname'=>'my_database',
    'fetch_mode'=>'PDO::FETCH_ASSOC',//这里的问题
    'prefix'=>''

    ),

不过为了美观,我还是决定不改 config 了,于是................:

  $stmt->setFetchMode(constant($this->fetch_mode));//这里必须使用int $model  constant($this->fetch_mode)

文档的解释:

constant    ( string $name   ) : mixed

通过 name 返回常量的值。

当你不知道常量名,却需要获取常量的值时, constant() 就很有用了。也就是常量名储存在一个变量里,或者由函数返回常量名。

返回常量的值。如果常量未定义则返回 NULL 。

推荐:php视频教程

以上就是mode must be an integer,该如何解决?的详细内容!

查看更多关于mode must be an integer,该如何解决?的详细内容...

  阅读:45次