Foros del Web » Programando para Internet » PHP »

[SOLUCIONADO] Consultar a dos bases de datos con ADODB

Estas en el tema de Consultar a dos bases de datos con ADODB en el foro de PHP en Foros del Web. Buenas. Me gustaría saber cómo puedo cómo podría hacer una consulta entre dos tablas en dos bases de datos distintas con ADODB. Se supone que ...
  #1 (permalink)  
Antiguo 15/05/2014, 09:40
 
Fecha de Ingreso: mayo-2014
Ubicación: Venezuela
Mensajes: 5
Antigüedad: 10 años, 6 meses
Puntos: 0
Pregunta Consultar a dos bases de datos con ADODB

Buenas.

Me gustaría saber cómo puedo cómo podría hacer una consulta entre dos tablas en dos bases de datos distintas con ADODB. Se supone que quiero intentar hacer eso para conectarme a dos bases de datos en un mismo servidor de SQL Server e___e... Sé hacerlo creando dos objetos de conexión, pero quisiera hacerlo con uno solo, ya que trabajar con dos es bastante engorroso (para mí), así que si alguien puede ayudarme lo agradezco desde ya :D

Saludos. Muchas gracias.

Última edición por Synchro; 15/05/2014 a las 09:51
  #2 (permalink)  
Antiguo 15/05/2014, 09:55
Avatar de hhs
hhs
Colaborador
 
Fecha de Ingreso: junio-2013
Ubicación: México
Mensajes: 2.995
Antigüedad: 11 años, 4 meses
Puntos: 379
Respuesta: Consultar a dos bases de datos con ADODB

http://adodb.sourceforge.net/adodb-faq.html#2connection

Hay vienen las opciones para solucionar tu problema.
__________________
Saludos
About me
Laraveles
A class should have only one reason to change.
  #3 (permalink)  
Antiguo 15/05/2014, 09:59
Avatar de Italico76  
Fecha de Ingreso: abril-2007
Mensajes: 3.303
Antigüedad: 17 años, 7 meses
Puntos: 292
Respuesta: Consultar a dos bases de datos con ADODB

EDIT: posteo errado...... "paso"
__________________
Salu2!
  #4 (permalink)  
Antiguo 15/05/2014, 10:05
 
Fecha de Ingreso: mayo-2014
Ubicación: Venezuela
Mensajes: 5
Antigüedad: 10 años, 6 meses
Puntos: 0
Respuesta: Consultar a dos bases de datos con ADODB

Muchas gracias. Pero no responde mi pregunta; puedo trabajar sin problemas estableciendo dos objetos de conexión y consultando entre uno y otro, y así es como lo he venido haciendo. Lo que realmente quisiera hacer es establecer un solo objeto de conexión para trabajar con las dos bases de datos para hacer las consultas, especificando en la consulta a qué campo de qué tabla de qué base de datos me estoy refiriendo, como cuando uno trabaja con MySQL, que puedes poner tipo:
Código PHP:
mysql_query("SELECT * FROM base1.tabla1 B1, base2.tabla1 B2 WHERE B1.campo1=B2.campo1",$conexion); 
A mí, me gustaría colocar algo así:

Código PHP:
$consulta=$conexion->Execute("SELECT * FROM base1.tabla1 B1, base2.tabla1 B2 WHERE B1.campo1=B2.campo1"); 
Cuando especifico el DSN de la conexión, no he visto forma de especificar más de una base de datos, o ninguna (tomando de nuevo el ejemplo de MySQL)

Código PHP:
// Creamos un objeto de conexión a SQL Server
$conexion ADONewConnection('odbc_mssql');

if (!
$conexion) die("Connection failed");
        
// Definimos nuestro DSN
$datos 'Driver={SQL Server};Server=Servidor;Database=base1';

// Hacemos la conexión con los parámetros correspondientes
if (!$conexion->Connect($datos,"","")) die ($conexion->ErrorMsg()); 
 
return 
$conexion
Esto no puede hacerse:

Código PHP:
//EJEMPLO
$datos 'Driver={SQL Server};Server=Servidor;Database=base1,base2'

:(
  #5 (permalink)  
Antiguo 15/05/2014, 13:01
 
Fecha de Ingreso: mayo-2014
Ubicación: Venezuela
Mensajes: 5
Antigüedad: 10 años, 6 meses
Puntos: 0
Respuesta: Consultar a dos bases de datos con ADODB

Ya lo resolví (por si a alguien le sirve)

Código PHP:
$conexion ADONewConnection('odbc_mssql');

if (!
$conexion) die("Connection failed");
        
//SE DEJA DATABASE DECLARADO DE ESTA MANERA PARA NO REFERENCIAR A NINGUNA BASE DE DATOS EN ESPECÍFICO
$datos 'Driver={SQL Server};Server=Servidor;Database=';

if (!
$conexion->Connect($datos,"","")) die ($conexion->ErrorMsg()); 
 
return 
$conexion
Entonces, la consulta queda:
Código PHP:
$consulta=$conexion->Execute("SELECT * FROM base1.dbo.tabla1 B1, base2.dbo.tabla1 B2 WHERE B1.campo1=B2.campo1"); 
(No olvidar el dbo si se trabaja en sql server ya que si no, la aplicación dice que el objeto no existe cuando haga la consulta)

Etiquetas: adodb, bases, consultar, tabla
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 14:48.