php fetch mode,php运行出现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);//这里报错

//

代码提示: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视频教程

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值