J'ai rencontré un problème aujourd'hui lors de l'écriture d'un framework mvc personnalisé :
SQLSTATE[HY000] : Erreur générale : le mode doit être un entier
Collez le code ci-dessous :
//这是报错位置的代码 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); } }
Invite de code : Erreur générale : le mode doit être un entier, j'ai relu le document
PDOStatement::fetchAll([ int $fetch_style [, mixed $fetch_argument [, array $ctor_args = array() ]]] ) : array
Il est marqué ici que $fetch_style
doit être de type int
, puis j'ai directement changé $this->fetch_mode
directement, je l'ai changé en PDO::FETCH_ASSOC
et j'ai constaté qu'il fonctionnait avec succès. Plus tard, j'ai découvert que mon config
stocké dedans s'est avéré être un type de chaîne :
'database'=>array( 'type'=>'mysql', 'host'=>'localhost', 'port'=>'3306', 'user'=>'root', 'pass'=>'root', 'charset'=>'utf8', 'dbname'=>'my_database', 'fetch_mode'=>'PDO::FETCH_ASSOC',//这里的问题 'prefix'=>'' ),
Mais par souci de beauté, je l'ai changé. décidé de ne pas changer config
, donc............... :
$stmt->setFetchMode(constant($this->fetch_mode));//这里必须使用int $model constant($this->fetch_mode)
Explication du document :
constant ( string $name ) : mixed
renvoie la valeur d'une constante via name
.
Lorsque vous ne connaissez pas le nom de la constante mais que vous avez besoin d'obtenir la valeur de la constante, constant()
est très utile. Autrement dit, le nom de la constante est stocké dans une variable ou le nom de la constante est renvoyé par une fonction.
Renvoie la valeur de la constante. Renvoie NULL
si la constante n'est pas définie.
Recommandé : Tutoriel vidéo php
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!