【问题标题】:Can we use two database in same view in Codeigniter?我们可以在 Codeigniter 的同一个视图中使用两个数据库吗?
【发布时间】:2016-04-20 11:20:15
【问题描述】:

我想访问来自两个不同数据库的数据。

我想将两个数据库中的记录打印到同一个视图中。

现在我的第一个查询来自另一个数据库,然后第二个查询来自默认数据库。所以我收到一个错误,即 SecondDatabase.tablenmae 不存在,实际上该表在默认数据库中

所以我这样定义它们:

$active_group = 'default';
$active_record = TRUE;
$db['default']['hostname'] = 'localhost';
$db['default']['username'] = 'root';
$db['default']['password'] = '';
$db['default']['database'] = 'biz_prov';
$db['default']['dbdriver'] = 'mysql';
$db['default']['dbprefix'] = '';
$db['default']['pconnect'] = TRUE;
$db['default']['db_debug'] = TRUE;
$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;

$db['bizlms']['hostname'] = 'localhost';
$db['bizlms']['username'] = 'root';
$db['bizlms']['password'] = '';
$db['bizlms']['database'] = 'bizlms';
$db['bizlms']['dbdriver'] = 'mysql';
$db['bizlms']['dbprefix'] = '';
$db['bizlms']['pconnect'] = FALSE;
$db['bizlms']['db_debug'] = TRUE;
$db['bizlms']['cache_on'] = TRUE;
$db['bizlms']['cachedir'] = '';
$db['bizlms']['char_set'] = 'utf8';
$db['bizlms']['dbcollat'] = 'utf8_general_ci';
$db['bizlms']['swap_pre'] = '';
$db['bizlms']['autoinit'] = TRUE;
$db['bizlms']['stricton'] = TRUE;

现在在我的视图中,我有一行从默认数据库中获取数据。

然后在第二行我想要来自另一个数据库的数据,所以我加载了那个数据库:

$this->db = $this->load->database('bizlms', TRUE);

但是对于我从默认数据库获取数据的第一行,我得到一个错误:

表 bizlms.tablname 不存在

如何在同一个视图上同时使用两个数据库?

【问题讨论】:

  • 在第二个数据库中将此 $db['bizlms']['stricton'] = TRUE; 设置为 FALSE
  • 我应该在哪里设置这个?
  • 你能看到这个吗:$db['bizlms']['stricton'] = TRUE;
  • 好的,我知道了,我希望这有效

标签: php codeigniter


【解决方案1】:

是的,您可以使用 2 个或更多数据库来获取信息,然后将其显示在视图上

应用程序/config/database.php

$active_group = 'default';

$db['default']['hostname'] = "host";
$db['default']['username'] = "username";
$db['default']['password'] = "password";
$db['default']['database'] = "database1";
$db['default']['dbdriver'] = "mysqli";
$db['default']['dbprefix'] = "";
$db['default']['pconnect'] = TRUE;
$db['default']['db_debug'] = TRUE;
$db['default']['cache_on'] = FALSE;
$db['default']['cachedir'] = "";
$db['default']['char_set'] = "utf8";
$db['default']['dbcollat'] = "utf8_general_ci";

$db['stats']['hostname'] = "host2";
$db['stats']['username'] = "username";
$db['stats']['password'] = "password";
$db['stats']['database'] = "database2";
$db['stats']['dbdriver'] = "mysqli";
$db['stats']['dbprefix'] = "";
$db['stats']['pconnect'] = TRUE;
$db['stats']['db_debug'] = TRUE;
$db['stats']['cache_on'] = FALSE;
$db['stats']['cachedir'] = "";
$db['stats']['char_set'] = "utf8";
$db['stats']['dbcollat'] = "utf8_general_ci";

controller.php

function do_somthing(){
    $this->load->model(array('model_db1', 'model_db2'));

    $info_db1  = $this->model_db1->get_info1();
    $info_db2  = $this->model_db2->get_info2();

    $data      = array(
                       'info1'  =>  $info_db1,
                       'ifno2'  =>  $info_db2
                      );

    $this->load->view('view', $data);
}

model_db1.php

public function __construct(){
    parent::__construct();

    $database1 = $this->load->database('default', TRUE);
}

function get_ifno1(){
    return $database1->db->get('table')->result();
}

model_db2.php

public function __construct(){
    parent::__construct();

    $database2 = $this->load->database('stats', TRUE);
}

function get_ifno2(){
    return $database2->db->get('table')->result();
}

view.php

<div>
    <?php var_dump($info1)?> 
</div> 
<hr>
<div>
    <?php var_dump($info2)?> 
</div> 

【讨论】:

    【解决方案2】:

    尝试这样,将数据库名称保存在一个变量中并使用该变量获取数据:

    <?php 
    $dsn1 = 'mysql://root@localhost/biz_prov'; 
    $db1 = $this->load->database($dsn1, true); 
    $user_table = $this->session->userdata('user_table'); 
    $db1->select($user_table.'.id,display_name,ext,email,auth_user,base_ini_filename,base_ini_id,custom_ini_filename,uc_user,uc_password'); 
    $db1->where($user_table.'.site_key',$site_item); 
    $db1->join('base_ini','base_ini.id ='.$user_table.'.base_ini_id'); 
    $db1->from($user_table); 
    $query = $db1->get(); 
    $result = $query->result_array(); 
    ?>
    

    【讨论】:

      猜你喜欢
      • 2021-06-25
      • 1970-01-01
      • 2016-11-23
      • 1970-01-01
      • 2012-07-10
      • 1970-01-01
      • 1970-01-01
      • 2020-08-09
      • 2017-06-15
      相关资源
      最近更新 更多