今天在寫自訂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#int#int# ,後來我直接將$this->fetch_mode
直接改成PDO::FETCH_ASSOC
,發現運作成功,後來翻到我的config
裡面儲存的竟然是個字串型別:<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">&#39;database&#39;=>array(
&#39;type&#39;=>&#39;mysql&#39;,
&#39;host&#39;=>&#39;localhost&#39;,
&#39;port&#39;=>&#39;3306&#39;,
&#39;user&#39;=>&#39;root&#39;,
&#39;pass&#39;=>&#39;root&#39;,
&#39;charset&#39;=>&#39;utf8&#39;,
&#39;dbname&#39;=>&#39;my_database&#39;,
&#39;fetch_mode&#39;=>&#39;PDO::FETCH_ASSOC&#39;,//这里的问题
&#39;prefix&#39;=>&#39;&#39;
),</pre><div class="contentsignin">登入後複製</div></div>
不過為了美觀,我還是決定不改
了,於是................:<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false"> $stmt->setFetchMode(constant($this->fetch_mode));//这里必须使用int $model constant($this->fetch_mode)</pre><div class="contentsignin">登入後複製</div></div>
文檔的解釋:
constant ( string $name ) : mixed
傳回常數的值。 當你不知道常數名,卻需要取得常數的值時,
就很有用了。也就是常數名儲存在一個變數裡,或是由函數傳回常數名。 傳回常數的值。如果常數未定義則傳回
。 推薦:
以上是php運行出現mode must be an integer,該如何解決?的詳細內容。更多資訊請關注PHP中文網其他相關文章!