[英]how to switch database in codeigniter
我是CI的新手,我只想知道有沒有辦法在CI中切換數據庫,例如:在登錄頁面中,有一個下拉列表,您可以指定要連接的數據庫,查看如下所示
<select name="select" id="select" >
<option value="1">DB1</option>
<option value="2">DB2</option>
</select>
我在database.php中有兩個數據庫,一個是default
的,另一個是default
的local
我正在使用默認的數據庫。
$active_group = 'default'; $active_record = TRUE;
我的問題是如何根據下拉值指定db,如果我選擇DB1,連接到默認值,DB2轉到本地....我知道如何通過以下方式手動切換db:
$this->load->database('default', TRUE); OR
$this->load->database('local', TRUE);
由於我有不同的控制器和模型,我怎么能實現這一點...我嘗試過:首先在登錄功能中獲取dropdownlist的值:
$this->load->model('My_Model');
$db = $this->input->post('select')
$this->My_Model->getDB($db);
然后在我的模型中我得到了功能:
function getDB($db)
{
if($db ==1)
{
$this->db = $this->load->database('default', TRUE);
}
elseif($db ==2)
{
$this->db = $this->load->database('local', TRUE);
}
}
不幸的是,它不起作用.....任何幫助都會得到很多贊賞!!!!
我得到了它的工作。 首先,我編輯了我的database.php配置文件以包含新數據庫。 然后,在我的模型中,我聲明了一個類變量$current_db
,並編寫了以下兩個函數:
function getDB($db){
if($db ==1){
$this->current_db = $this->load->database('default', TRUE);
} elseif($db ==2) {
$this->current_db = $this->load->database('local', TRUE);
}
}
function dyno_query($table, $id){
$query = $this->current_db->get_where($table, array('id' => $id));
return $query->result_array();
}
然后在我的控制器中,我運行了以下內容:
$arr = array();
$this->My_Model->getDB(1);
$arr['default'] = $this->My_Model->dyno_query('default_table', 2);
$this->My_Model->getDB(2);
$arr['local'] = $this->My_Model->dyno_query('local_table', 74);
var_dump($arr);
結果是一個包含來自兩個數據庫的數據的數組。 也許這一切的關鍵是定義一個名稱不是$ db的類變量。
編輯:
要在每個頁面加載時加載當前數據庫,您需要使用會話。 在處理下拉數據的控制器函數中,您可以輸入類似於以下內容的內容:
$db = $this->input->post('select')
$this->My_Model->getDB($db);
$this->session->set_userdata($db);
在將使用數據庫的任何控制器中,您將要添加代碼以加載當前數據庫:
function __construct(){
parent::__construct();
$this->load->model('My_Model');
$db = $this->session->userdata('db');
$this->My_Model->getDB($db);
}
編輯:
如果您需要從各種模型訪問相同的數據庫,我建議使用EllisLab的mddd庫。 只需使用下面的代碼創建一個名為Db_manager.php的PHP文件,並將其放入application / libraries目錄:
class Db_manager
{
var $connections = array();
var $CI;
function __construct()
{
$this->CI =& get_instance();
}
function get_connection($db_name)
{
// connection exists? return it
if (isset($this->connections[$db_name]))
{
return $this->connections[$db_name];
}
else
{
// create connection. return it.
$this->connections[$db_name] = $this->CI->load->database($db_name, true);
return $this->connections[$db_name];
}
}
}
在將使用數據庫的每個模型的構造函數中添加以下內容:
var $current_db;
function __construct(){
parent::__construct();
$this->load->library('Db_manager');
$db = $this->session->userdata('db');
if ($db == 1){
$this->current_db = $this->db_manager->get_connection('default');
} else {
$this->current_db = $this->db_manager->get_connection('alternate');
}
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.