小编给大家分享一下遇到SQLSTATE[HY000]: General error: mode must be an integer的问题怎么办,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!
创新互联是一家专注于网站建设、成都网站制作与策划设计,延川网站建设哪家好?创新互联做网站,专注于网站建设10余年,网设计领域的专业建站公司;建站业务涵盖:延川等地区。延川做网站价格咨询:18982081108
今天在写自定义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
。
看完了这篇文章,相信你对“遇到SQLSTATE[HY000]: General error: mode must be an integer的问题怎么办”有了一定的了解,如果想了解更多相关知识,欢迎关注创新互联行业资讯频道,感谢各位的阅读!
售后响应及时
7×24小时客服热线数据备份
更安全、更高效、更稳定价格公道精准
项目经理精准报价不弄虚作假合作无风险
重合同讲信誉,无效全额退款