CodeIgniter內建的資料庫類使用介紹_PHP教程

來源:互聯網
上載者:User
在 CodeIgniter 中,使用資料庫是非常頻繁的事情。你可以使用架構內建的資料庫類,就能便捷地進行資料庫操作。

初始化資料庫類

依據你的資料庫配置載入並初始化資料庫類:

$this->load->database();

被載入之後你可以在任何地方使用它。

以對象形式返回查詢結果

$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()函數返回一個對象的數組。例如:$row->title

以數組形式返回查詢結果

$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()函數返回一個帶下標的數組。例如:$row['title']

返回一條資料

對象形式:

$query = $this->db->query('SELECT name FROM my_table LIMIT 1');$row = $query->row();echo $row->name;

上面的row()函數返回一個 對象。例如:$row->name

數組形式:

$query = $this->db->query('SELECT name FROM my_table LIMIT 1');$row = $query->row_array();echo $row['name'];

上面的row_array()函數返回一個 數組。例如:$row['name']

插入(insert)資料

$sql = "INSERT INTO mytable (title, name)         VALUES (".$this->db->escape($title).", ".$this->db->escape($name).")";$this->db->query($sql);echo $this->db->affected_rows();

快捷插入方式:

$data = array(               'title' => $title,               'name' => $name,               'date' => $date            );$this->db->insert('mytable', $data); // Produces: INSERT INTO mytable (title, name, date) VALUES ('{$title}', '{$name}', '{$date}')

資料庫配置

CodeIgniter 有一個設定檔讓你存放資料庫連接值(username:使用者名稱,password:密碼,database name:資料庫名,等等..). 設定檔位於以下路徑:application/config/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";

使用多維陣列的原因是為了讓你隨意的儲存多個串連值的設定。舉例:如果你運行多個環境(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";

那麼,告訴系統使用"test"組,你可以設定位於設定檔中的變數:

$active_group = "test";

注意: "test"的名字是任意的,這可以讓你自由設定,我們的主要串連預設使用"default"這個名字,當然,您可以基於您的項目為它起一個更有意義的名字。

Active Record

Active Record 類 可以通過資料庫設定檔裡的$active_record變數進行全域的設定(允許/禁止 TRUE/FALSE (boolean)). 如果你不用這個類,哪麼你可以通過將這個變數值設定成FALSE來減少在資料庫類初始化時對電腦資源的消耗。 $active_record = TRUE;

注意: 一些CodeIgniter的類,例如Sessions,在執行一些函數的時候需要Active Records的支援。

參數解析:

  • hostname - 資料庫的主機名稱,通常位於本機,可以表示為 "localhost". 
  • username - 需要串連到資料庫的使用者名稱. 
  • password - 登陸資料庫的密碼. 
  • database - 你需要串連的資料庫名. 
  • dbdriver - 資料庫類型。如:mysql、postgres、odbc 等。必須為小寫字母。 
  • dbprefix - 當運行Active Record查詢時資料表的首碼,它允許在一個資料庫上安裝多個CodeIgniter程式. 
  • pconnect - TRUE/FALSE (boolean) - 使用持續串連. 
  • db_debug - TRUE/FALSE (boolean) - 顯示資料庫錯誤資訊. 
  • cache_on - TRUE/FALSE (boolean) - 資料庫查詢快取是否開啟,詳情請見資料庫緩衝類。 
  • cachedir - 資料庫查詢快取目錄所在的伺服器絕對路徑。 
  • char_set - 與資料庫通訊時所使用的字元集。 
  • dbcollat - 與資料庫通訊時所使用的字元規則(character collation )。 
  • port - 資料庫連接埠號碼. 當前只用於 Postgres 驅動程式. 要使用這個值,你應該添加一行代碼到資料庫配置數組。

記錄一下,方便查閱。

http://www.bkjia.com/PHPjc/752321.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/752321.htmlTechArticle在 CodeIgniter 中,使用資料庫是非常頻繁的事情。你可以使用架構內建的資料庫類,就能便捷地進行資料庫操作。 初始化資料庫類 依據你的...

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.