PDOStatement::setFetchMode()問題

來源:互聯網
上載者:User
function fetch($query='', $type = 'BOTH') {    $result_type="PDO::FETCH_".$type;    $query->setFetchMode($result_type);//這報錯,$query是pdo的query結果    $result_arr=$query->fetch();    return $result_arr;}

PDOStatement::setFetchMode(): SQLSTATE[HY000]: General error: mode must be an integer
這個是什麼問題?本地測試沒問題,放空間報錯

回複內容:

function fetch($query='', $type = 'BOTH') {    $result_type="PDO::FETCH_".$type;    $query->setFetchMode($result_type);//這報錯,$query是pdo的query結果    $result_arr=$query->fetch();    return $result_arr;}

PDOStatement::setFetchMode(): SQLSTATE[HY000]: General error: mode must be an integer
這個是什麼問題?本地測試沒問題,放空間報錯

no code, no truth.

你得把代碼和資料庫從你的項目中抽出來並盡量簡化,以便於其它人在自己的電腦上重現你遇到的問題,再來分析。

PDO擴充在Windows環境和Linux環境的行為不相同,有的代碼在Windows環境是不報錯的(warning、notice全開啟也不報),但在linux環境就會報錯的,我7年前遇到過。

改一行代碼:

$query->setFetchMode(constant($result_type));

PDOStatement::setFetchMode方法必須傳入第一個int型的mode參數啊,你肯定沒傳或者傳的不是int型的。至於本地測試沒報錯,可能是service的錯誤輸出層級跟空間的不一樣。

PDOStatement::setFetchMode ( int $mode );//mode//The fetch mode must be one of the PDO::FETCH_* constants.

一個更好的方法,有圖有真相:

你理解錯文檔的意思了,那是要你填一個PDO的常量,不是字串。

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.