thinkphp框架解決數據庫字段大小問題

在使用thinkphp的時候,我遇到過數據庫字段名大小寫的問題,使用M()方法的時候,thinkphp默認會尋找小寫的數據庫字段,通過以下方法解決了:

就是修改thinkphp的源碼中的Library/Db/Driver.class.php文件,把

PDO::ATTR_CASE => PDO::CASE_LOWER 改爲 PDO::ATTR_CASE => PDO::CASE_NATURAL,

或者在配置文件裏面增加

DB_PARAMS’    =>    array(\PDO::ATTR_CASE => \PDO::CASE_NATURAL) 這一句。

第一次使用的時候這種解決方法果然可以,但是做另外一個項目的時候卻始終不生效,無奈,百度了半天,找到一個方法,因爲thinkphp執行的時候默認會把大寫轉換成小寫,所以我們找到它的源碼不讓它轉換就行。

修改Common/functions.php裏面的parse_name函數源碼爲:


function parse_name($name, $type=0) {
   /* if ($type) {
        return ucfirst(preg_replace_callback('/_([a-zA-Z])/', function($match){return strtoupper($match[1]);}, $name));
    } else { 
    //這裏會將數據庫表名裏的大寫轉換爲 _小寫,修改成不轉換
     return strtolower(trim(preg_replace("/[A-Z]/", "_\\0", $name), "_"));
    }*/
    return $name;
}

其中註釋掉的是原來的,未註釋是新增的。

修改Library/Think/Model.class.php裏面的getTableName函數:


 //$this->trueTableName    =   strtolower($tableName); //這裏會將表名轉換成小寫,修改成不轉換
$this->trueTableName    =   $tableName;

修改其中一句,這樣就可以解決數據庫字段名大寫的問題。


本文分享自微信公衆號 - 卡二條的技術圈(qq1005349393)。
如有侵權,請聯繫 [email protected] 刪除。
本文參與“OSC源創計劃”,歡迎正在閱讀的你也加入,一起分享。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章