codeigniter自帶數(shù)據(jù)庫類使用方法說明
初始化數(shù)據(jù)庫類
依據(jù)你的數(shù)據(jù)庫配置載入并初始化數(shù)據(jù)庫類:
this->load->database();
被載入之后你可以在任何地方使用它。
以對象形式返回查詢結(jié)果
$query = $this->db->query('SELECT name, title, email FROM my_table');
foreach ($query->result() as $row)
{
echo $row->title;
echo $row->name;
echo $row->email;
}
echo 'Total Results: ' . $query->num_rows();
上面的result()函數(shù)返回一個對象的數(shù)組。例如:$row->title
以數(shù)組形式返回查詢結(jié)果
$query = $this->db->query('SELECT name, title, email FROM my_table');
foreach ($query->result_array() as $row)
{
echo $row['title'];
echo $row['name'];
echo $row['email'];
}
上面的result_array()函數(shù)返回一個帶下標(biāo)的數(shù)組。例如:$row['title']
返回一條數(shù)據(jù)
對象形式:
$query = $this->db->query('SELECT name FROM my_table LIMIT 1');
$row = $query->row();
echo $row->name;
上面的row()函數(shù)返回一個 對象。例如:$row->name
數(shù)組形式:
$query = $this->db->query('SELECT name FROM my_table LIMIT 1');
$row = $query->row_array();
echo $row['name'];
上面的row_array()函數(shù)返回一個 數(shù)組。例如:$row['name']
插入(insert)數(shù)據(jù)
$sql = "INSERT INTO mytable (title, name)
VALUES (".$this->db->escape($title).", ".$this->db->escape($name).")";
$this->db->query($sql);
echo $this->db->affected_rows();
數(shù)據(jù)庫配置
CodeIgniter 有一個配置文件讓你存放數(shù)據(jù)庫連接值(username:用戶名,password:密碼,database name:數(shù)據(jù)庫名,等等..). 配置文件位于以下路徑:application/config/database.php
配件文件存放在一個如下格式的一個多維數(shù)組里:
$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";
使用多維數(shù)組的原因是為了讓你隨意的存儲多個連接值的設(shè)置。舉例:如果你運(yùn)行多個環(huán)境(development:開發(fā)、production:制作、test:測試 等等..),你能為每個環(huán)境建立獨(dú)立的連接組,并在組直接進(jìn)行切換。舉例,設(shè)置一個"test"環(huán)境,你可以這樣做:
$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";
那么,告訴系統(tǒng)使用"test"組,你可以設(shè)置位于配置文件中的變量:
$active_group = "test";
注意: "test"的名字是任意的,這可以讓你自由設(shè)置,我們的主要連接默認(rèn)使用"default"這個名字,當(dāng)然,您可以基于您的項(xiàng)目為它起一個更有意義的名字。
Active Record
Active Record 類 可以通過數(shù)據(jù)庫配置文件里的$active_record變量進(jìn)行全局的設(shè)定(允許/禁止 TRUE/FALSE (boolean)). 如果你不用這個類,哪么你可以通過將這個變量值設(shè)置成FALSE來減少在數(shù)據(jù)庫類初始化時對電腦資源的消耗。 $active_record = TRUE;
注意: 一些CodeIgniter的類,例如Sessions,在執(zhí)行一些函數(shù)的時候需要Active Records的支持。
參數(shù)解析:
hostname - 數(shù)據(jù)庫的主機(jī)名,通常位于本機(jī),可以表示為 "localhost".
username - 需要連接到數(shù)據(jù)庫的用戶名.
password - 登陸數(shù)據(jù)庫的密碼.
database - 你需要連接的數(shù)據(jù)庫名.
dbdriver - 數(shù)據(jù)庫類型。如:mysql、postgres、odbc 等。必須為小寫字母。
dbprefix - 當(dāng)運(yùn)行Active Record查詢時數(shù)據(jù)表的前綴,它允許在一個數(shù)據(jù)庫上安裝多個CodeIgniter程序.
pconnect - TRUE/FALSE (boolean) - 使用持續(xù)連接.
db_debug - TRUE/FALSE (boolean) - 顯示數(shù)據(jù)庫錯誤信息.
cache_on - TRUE/FALSE (boolean) - 數(shù)據(jù)庫查詢緩存是否開啟,詳情請見數(shù)據(jù)庫緩存類。
cachedir - 數(shù)據(jù)庫查詢緩存目錄所在的服務(wù)器絕對路徑。
char_set - 與數(shù)據(jù)庫通信時所使用的字符集。
dbcollat - 與數(shù)據(jù)庫通信時所使用的字符規(guī)則(character collation )。
port - 數(shù)據(jù)庫端口號. 當(dāng)前只用于 Postgres 驅(qū)動程序. 要使用這個值,你應(yīng)該添加一行代碼到數(shù)據(jù)庫配置數(shù)組。
- CodeIgniter配置之a(chǎn)utoload.php自動加載用法分析
- CI框架中類的自動加載問題分析
- CI框架自動加載session出現(xiàn)報錯的解決辦法
- CI框架實(shí)現(xiàn)創(chuàng)建自定義類庫的方法
- 詳談配置phpstorm完美支持Codeigniter(CI)代碼自動完成(代碼提示)
- CodeIgniter自定義控制器MY_Controller用法分析
- CodeIgniter實(shí)現(xiàn)從網(wǎng)站抓取圖片并自動下載到文件夾里的方法
- CodeIgniter采用config控制的多語言實(shí)現(xiàn)根據(jù)瀏覽器語言自動轉(zhuǎn)換功能
- 讓CodeIgniter數(shù)據(jù)庫緩存自動過期的處理的方法
- 解析CodeIgniter自定義配置文件
- php框架CI(codeigniter)自動加載與自主創(chuàng)建對象操作實(shí)例分析
相關(guān)文章
Zend Framework框架教程之Zend_Db_Table_Rowset用法實(shí)例分析
這篇文章主要介紹了Zend Framework框架教程之Zend_Db_Table_Rowset用法,結(jié)合實(shí)例形式分析了Zend_Db_Table_Rowset操作結(jié)果集的相關(guān)技巧,需要的朋友可以參考下2016-03-03
淺析PHP反序列化中過濾函數(shù)使用不當(dāng)導(dǎo)致的對象注入問題
這篇文章主要介紹了PHP反序列化中過濾函數(shù)使用不當(dāng)導(dǎo)致的對象注入問題,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下2020-02-02
php 從一個數(shù)組中隨機(jī)的取出若干個不同的數(shù)實(shí)例
本文章向碼農(nóng)介紹php從一個不重復(fù)的數(shù)組中隨機(jī)的取出若干個不同的元素,難點(diǎn)是防止在取數(shù)的時候出現(xiàn)已經(jīng)取到過的情況(特別是取到最后),需要盡可能的降低碰撞,需要的朋友可以參考下2016-12-12
Laravel 5.1 框架Blade模板引擎用法實(shí)例分析
這篇文章主要介紹了Laravel 5.1 框架Blade模板引擎用法,結(jié)合實(shí)例形式分析了laravel5.1框架Blade模板引擎基本功能、創(chuàng)建、使用方法及相關(guān)操作注意事項(xiàng),需要的朋友可以參考下2020-01-01

