我有一些(模型)方法,它们分别连接到不同的数据库。
i从数据库中创建了两个数据库配置,将它们加载到模型中并创建了两种方法。一个连接到DB1,另一个连接到DB2。(下面的示例代码)
当我替换 $ this-> db by $ db1 或 $ db2 时,我会遇到以下错误:
Message: Undefined variable: DB1 // or DB2
否则,我得到了这个错误:
Message: Undefined property: Home::$db
我尝试在每种方法中连接到特定数据库中的每种方法中都将 $ db = $ db = $ the-> load-> load->数据库(" database_name",true); 中。它可以工作,但我知道这不是我重复使用该方法时一次又一次连接它的好习惯。
我真的很困惑。
以下是我的代码:
database.php
$db['db1'] = array(
'dsn' => '',
'hostname' => 'localhost',
'username' => 'root',
'password' => '',
'database' => 'db1',
'dbdriver' => 'mysqli',
'dbprefix' => '',
'pconnect' => FALSE,
'db_debug' => (ENVIRONMENT !== 'production'),
'cache_on' => FALSE,
'cachedir' => '',
'char_set' => 'utf8',
'dbcollat' => 'utf8_general_ci',
'swap_pre' => '',
'encrypt' => FALSE,
'compress' => FALSE,
'stricton' => FALSE,
'failover' => array(),
'save_queries' => TRUE
);
$db['db2'] = array(
'dsn' => '',
'hostname' => 'other_host',
'username' => 'root',
'password' => '',
'database' => 'db2',
'dbdriver' => 'mssql',
'dbprefix' => '',
'pconnect' => FALSE,
'db_debug' => (ENVIRONMENT !== 'production'),
'cache_on' => FALSE,
'cachedir' => '',
'char_set' => 'utf8',
'dbcollat' => 'utf8_general_ci',
'swap_pre' => '',
'encrypt' => FALSE,
'compress' => FALSE,
'stricton' => FALSE,
'failover' => array(),
'save_queries' => TRUE
);
模型:
function __construct()
{
parent::__construct();
$DB1= $this->load->database("db1", TRUE);
$DB2= $this->load->database("db2", TRUE);
}
public function get_from_db1($id)
{
// $query = $this->db->get_where("my_table1",array("ID"=>$id));
$query = $DB1->get_where("my_table1",array("ID"=>$id));
return $query->row_array();
}
public function get_from_db2($id)
{
// $query = $this->db->get_where("my_table2",array("ID"=>$id));
$query = $DB2->get_where("my_table2",array("ID"=>$id));
return $query->row_array();
}
也:
- 我声明并加载数据库吗?
- 我应该在控制器或模型中放置 $ this-> load-> load-> database(); 函数?
请帮助!
预先感谢!
您需要定义constructor
外部的变量public $DB1;
public $DB2;
并将其称为
内的构造函数function __construct()
{
parent::__construct();
$this->DB1= $this->load->database("db1", TRUE);
$this->DB2= $this->load->database("db2", TRUE);
}
和您的功能内部
public function get_from_db1($id)
{
// $query = $this->db->get_where("my_table1",array("ID"=>$id));
$query = $this->DB1->get_where("my_table1", array("ID" => $id));
return $query->row_array();
}
public function get_from_db2($id)
{
// $query = $this->db->get_where("my_table2",array("ID"=>$id));
$query = $this->DB2->get_where("my_table2", array("ID" => $id));
return $query->row_array();
}
您是否在autoload.php中加载了主数据库类:
$autoload['libraries'] = array('database');
您需要加载此库,以便可以使用$db
属性。