遇到SQLSTATE[HY000]: General error: mode must be an integer的问题

小编给大家分享一下遇到SQLSTATE[HY000]: General error: mode must be an integer的问题怎么办,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!

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

遇到SQLSTATE[HY000]: General error: mode must be an integer的问题

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

下面贴上代码:

//这是报错位置的代码
publicfunctiondao_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$modelconstant($this->fetch_mode)

文档的解释:

constant(string$name):mixed

通过 name 返回常量的值。

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

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

看完了这篇文章,相信你对“遇到SQLSTATE[HY000]: General error: mode must be an integer的问题怎么办”有了一定的了解,如果想了解更多相关知识,欢迎关注恰卡编程网行业资讯频道,感谢各位的阅读!

发布于 2021-03-13 15:40:14
收藏
分享
海报
0 条评论
181
上一篇:php怎么实现一个账号只能有一个人登录 下一篇:php如何安装uuid扩展
目录

    0 条评论

    本站已关闭游客评论,请登录或者注册后再评论吧~

    忘记密码?

    图形验证码