from http://codeigniter.org.cn/user_guide/database/configuration.html
CodeIgniter 有一個配置文件讓你存放數據庫連接值(username:用戶名,password:密碼,database name:數據庫名,等等..). 該配置文件位于application/config/database.php. 你也可以通過放置不同的database.php文件到特定的環境配置文件夾里來設置特定環境的數據庫連接值.
配件文件存放在一個如下格式的一個多維數組里:
$db['default']['hostname'] = "localhost";
$db['default']['username'] = "root";
$db['default']['password'] = "";
$db['default']['database'] = "database_name";
$db['default']['dbdriver'] = "mysql";
$db['default']['dbprefix'] = "";
$db['default']['pconnect'] = TRUE;
$db['default']['db_debug'] = FALSE;
$db['default']['cache_on'] = FALSE;
$db['default']['cachedir'] = "";
$db['default']['char_set'] = "utf8";
$db['default']['dbcollat'] = "utf8_general_ci";
$db['default']['swap_pre'] = "";
$db['default']['autoinit'] = TRUE;
$db['default']['stricton'] = FALSE;
我們使用多維數組的原因是為了讓你隨意的存儲多個連接值的設置。舉例:如果你運行多個環境(development:開發、production:生產、test:測試 等等..),你能為每個環境建立獨立的連接組,并在組直接進行切換。舉例,設置一個"test"環境,你可以這樣做:
$db['test']['hostname'] = "localhost";
$db['test']['username'] = "root";
$db['test']['password'] = "";
$db['test']['database'] = "database_name";
$db['test']['dbdriver'] = "mysql";
$db['test']['dbprefix'] = "";
$db['test']['pconnect'] = TRUE;
$db['test']['db_debug'] = FALSE;
$db['test']['cache_on'] = FALSE;
$db['test']['cachedir'] = "";
$db['test']['char_set'] = "utf8";
$db['test']['dbcollat'] = "utf8_general_ci";
$db['test']['swap_pre'] = "";
$db['test']['autoinit'] = TRUE;
$db['test']['stricton'] = FALSE;
那么,告訴系統使用"test"組,你可以設置位于配置文件中的變量:
$active_group = "test";
注意: "test"的名字是任意的,這可以讓你自由設置,我們的主要連接默認使用"default"這個名字,當然,您可以基于您的項目為它起一個更有意義的名字。
Active Record 類 可以通過數據庫配置文件里的$active_record變量進行全局的設定(允許/禁止 TRUE/FALSE (boolean)). 如果你不用這個類,那么你可以通過將這個變量值設置成FALSE來減少在數據庫類初始化時對電腦資源的消耗。
$active_record = TRUE;
注意: 一些CodeIgniter的類,例如Sessions,在執行一些函數的時候需要Active Records的支持。
提示: 就MYSQL或MYSQLi數據庫而言,如果服務器運行環境PHP版本小于5.2.3、MYSQL版本小于5.0.7,那么該項設置僅被用來備份(由數據庫維護類DB Forge所創建查詢)。如果使用多字節字符集并且使用低版本PHP環境中不兼容的mysql_real_escape_string()函數,它將使網站更容易受到SQL注入的危險。
曜日晨陽注: 如果設置了 $db['default']['dbprefix'] 的值 同時也設置了 $db['default']['swap_pre'] 的值,則會將查詢代碼中和$db['default']['swap_pre'] 的值一致的字符替換成 $db['default']['dbprefix'] 的值,如果沒有設置 $db['default']['swap_pre'] 值,就直接在數據庫表名前面加上 $db['default']['dbprefix'] 值。
$db['default']['port']
= 5432;
提示: 并不是所有的值都是必須的,這取決與您所使用的數據庫平臺,如(MySQL, Postgres, 等.) 例如, 當你使用SQLite時,你不需要提供username 或 password, 數據庫名字就是您數據庫文件的路徑. 以上內容假定您使用的是 MySQL 數據庫.