Foros del Web » Programando para Internet » PHP » CodeIgniter »

[SOLUCIONADO] Trabajar multples BD

Estas en el tema de Trabajar multples BD en el foro de CodeIgniter en Foros del Web. Hola colegas quisiera saber como puedo trabajar múltiples BD desde una sessión. Ahora me explico mejor. Tengo 2 bases de datos en un mismo servidor ...
  #1 (permalink)  
Antiguo 19/12/2012, 08:37
Usuario no validado
 
Fecha de Ingreso: septiembre-2007
Ubicación: Cuba
Mensajes: 202
Antigüedad: 16 años, 7 meses
Puntos: 5
Trabajar multples BD

Hola colegas
quisiera saber como puedo trabajar múltiples BD desde una sessión. Ahora me explico mejor. Tengo 2 bases de datos en un mismo servidor y lo único que varía es el el prefijo (es / en). Con esto lograría manejar el mismo contenido desde dos BD diferentes, especificando siempre desde cúal deseo trabajr. Me hago entender. Hice esto en config/database.php pero no me funcionó.

Código PHP:
$CI = &get_instance();
$db['default']['database'] = 'mibd_'.$CI->session->userdata('BD'); 
Alguna otra idea por favor, Gracias mil
  #2 (permalink)  
Antiguo 19/12/2012, 09:52
Avatar de quike88  
Fecha de Ingreso: agosto-2008
Mensajes: 471
Antigüedad: 15 años, 8 meses
Puntos: 87
Respuesta: Trabajar multples BD

Hola,

Podrías tener 2 entornos en el database.php:

Código PHP:
Ver original
  1. $db['es']['hostname'] = "localhost";
  2. $db['es']['username'] = "";
  3. $db['es']['password'] = "";
  4. $db['es']['database'] = "mibd_es";
  5. //....
  6. $db['en']['hostname'] = "localhost";
  7. $db['en']['username'] = "";
  8. $db['en']['password'] = "";
  9. $db['en']['database'] = "mibd_en";
  10. //....

Y en tu modelo defines cual usar:

Código PHP:
Ver original
  1. $this->db = $this->load->database($this->session->userdata('BD'), TRUE);

Donde $this->session->userdata('BD') debería contener es o en.

Otra opción sería tener solo un entorno y enviarle la bd:

Código PHP:
Ver original
  1. $config['database'] = 'mibd_'.$CI->session->userdata('BD');
  2. $this->db = $this->load->database("default", $config);

Un saludo.

Última edición por quike88; 19/12/2012 a las 09:59
  #3 (permalink)  
Antiguo 19/12/2012, 10:05
Usuario no validado
 
Fecha de Ingreso: septiembre-2007
Ubicación: Cuba
Mensajes: 202
Antigüedad: 16 años, 7 meses
Puntos: 5
Respuesta: Trabajar multples BD

Eso que eme xplicas está super bárbaro y responde a mi duda, pero ha generado otra. Có mo eso que me dices la final
Otra opción sería tener solo un entorno y enviarle la bd:
Código PHP:
Ver original
  1. $config['database'] = 'mibd_'.$CI->session->userdata('BD');
  2.     $this->db = $this->load->database("default", $config);

porque el probelam radica en que

Código PHP:
Ver original
  1. $CI->session->userdata('BD');
no funciona dentre del archivo de configuración

Cómo es eso de un solo entorno???
Salu2

Última edición por reyvi; 19/12/2012 a las 10:16
  #4 (permalink)  
Antiguo 19/12/2012, 10:24
Avatar de quike88  
Fecha de Ingreso: agosto-2008
Mensajes: 471
Antigüedad: 15 años, 8 meses
Puntos: 87
Respuesta: Trabajar multples BD

Hola,

En tu archivo database.php tienes:

Código PHP:
Ver original
  1. $db['default']['hostname'] = "localhost";
  2. $db['default']['username'] = "";
  3. $db['default']['password'] = "";
  4. $db['default']['database'] = "mibd";

Y en el constructor de tu modelo tienes:

Código PHP:
Ver original
  1. $config['database'] = 'mibd_'.$CI->session->userdata('BD');
  2. $this->db = $this->load->database("default", '', $config);

Te sugiero que revises la documentación.

Un saludo!
  #5 (permalink)  
Antiguo 19/12/2012, 11:11
Usuario no validado
 
Fecha de Ingreso: septiembre-2007
Ubicación: Cuba
Mensajes: 202
Antigüedad: 16 años, 7 meses
Puntos: 5
Respuesta: Trabajar multples BD

Hora siiiiiiiiiiiiiiiiiiiiiii gracias milllll

Etiquetas: Ninguno
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 09:42.