Blogdevphp

Codeigniter : Utiliser plusieurs bases de données

2014-03-22 codeigniter

 Le framework Codeigniter, a été conçu avec la possibilité de travailler avec plusieurs bases de données. Vous pouvez configurer les informations de chacunes de vos bases de données respectives.

Vous avez celle par défaut, dans votre fichier de configuration et vous pourrez ajouter d'autres bases de données selon vos besoins.

La manoeuvre n'est pas difficile à mettre en place et commence par le fichier de configuration database.php dans le dossier application.

Modification du fichier database.php

Nous allons commencer, par modifier ce fichier, pour renseigner les données de nos bases.

<?php

/***************************/
$active_group = 'default';
$active_record = TRUE;

$db['default']['hostname'] = 'localhost';
$db['default']['username'] = 'root';
$db['default']['password'] = '';
$db['default']['database'] = 'base1';
$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;

/******************************/

$active_group = 'test';
$active_record = TRUE;

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

?>

Ici, nous avons deux bases de données nommées base1 et base2. Si vous regardez bien, on remarque que la valeur 'active_group'  est utilisée par toutes les autres données comme premier paramètre. C'est justement cette information qui permet de distinguer chaque base de donnée et de pouvoir insérer, modifier, supprimer dans la base correspondante.

Modèle de donnée

Dans notre fichier model, nous allons spécifier toutes nos requêtes.

<?php

if (!defined('BASEPATH'))
    exit('No direct script access allowed');

class Menu2_model extends CI_Model {

    protected $table = 'menu';
    
 function __construct() {
  parent::__construct();
  $this->load->database('test', TRUE);
    }
 
 public function display_menu()
 {
 return $this->db->select('nom_menu')
                  ->order_by("id_menu", "desc")
                  ->get($this->table);

 }

    }

?>

Dans le constructeur, nous avons indiqué la base de donnée à utiliser. Elle sera effective pour l'ensemble des requêtes qui seront définies dans ce fichier.

<?php

if (!defined('BASEPATH'))
    exit('No direct script access allowed');
 
class Menu1_model extends CI_Model {
 
    protected $table = 'menu';
    
    function __construct() {
       parent::__construct();
       $this->load->database('default', TRUE);
    }
 
    public function display_menu()
    {
      return $this->db->select('nom_menu')
                       ->order_by("id_menu", "desc")
                       ->get($this->table);
    }
 
    }

?>

Pour l'exemple , on souhaite afficher les données du menu des deux bases de données.

Le contrôleur

<?php

if (!defined('BASEPATH'))
    exit('No direct script access allowed');

class front extends CI_Controller {

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

    public function index() {
    
    $data['base1'] = $this->menu1_model->display_menu();
    $data['base2'] = $this->menu2_model->display_menu();
    
    $this->load->view('accueil',$data);

    }

?>

Dans le contrôleur, on récupère les données, par les méthodes que nous avons définies dans nos modéles. Afin de pouvoir les afficher dans notre vue, on a ajouté un deuxième paramètre, $data qui contient les résultats des requêtes.

La vue

<div class="title">
  <h3>Accueil</h3>
</div>

<div id='menu_base1'>
<?php
$rows = $base1->result_array();
    foreach ($rows as $key => $value) {
 echo $value['nom_menu']; 
 }
?>
</div>

<div id='menu_base2'>
<?php
$rows = $base2->result_array();
    foreach ($rows as $key => $value) {
    echo $value['nom_menu']; 
 }
?>
</div>

?>

Conclusion

Voilà, vous savez utiliser plusieurs bases de données et vous pouvez travailler avec les données de celles-ci.

comments powered by Disqus
Copyright © 2018 blogdevphp.fr - Tous droits réservés