Foros del Web » Programando para Internet » PHP »

Duda con join : (

Estas en el tema de Duda con join : ( en el foro de PHP en Foros del Web. Buenas tardes, Mi consulta es muy sencilla, pero creo que no lo estoy haciendo bien (seguramente). Se trata de lo siguiente, pongo como son las ...
  #1 (permalink)  
Antiguo 23/02/2009, 13:09
 
Fecha de Ingreso: agosto-2008
Mensajes: 166
Antigüedad: 15 años, 8 meses
Puntos: 1
Duda con join : (

Buenas tardes,

Mi consulta es muy sencilla, pero creo que no lo estoy haciendo bien (seguramente). Se trata de lo siguiente, pongo como son las tablas y la consulta para que os sea más gráfico.

Tabla1:
Campo 1 4465
Campo 2 5568

Tabla2:
Idusuario 4465 5568
Nombreusuario TroyMcClure JonnhyMeLavo

$query = mysql_query("select * from tabla1 INNER JOIN tabla2 ON tabla1.campo1 = tabla2.idusuario OR tabla1.campo2 = tabla2.idusuario") or die("Error en query:".mysql_error() );
while($row4 = mysql_fetch_array($query)) {
echo $row4['nombreusuario'];
echo " vs ";
echo $row4['nombreusuario'];
echo "<br>";
}

En los echo, quiero sacar de cada registro de la tabla 1, el nombre del usuario del campo1 vs el nombre del usuario del campo2. En el ejemplo:
TroyMcClure vs JonnhyMeLavo

He intentado ser bastante gráfico para que lo entendierais bien. Cuando hago los echo no me sale lo que yo os pongo ahí. ¿Cómo puedo hacerlo?

Gracias y un saludo.
  #2 (permalink)  
Antiguo 23/02/2009, 13:49
Avatar de Triby
Mod on free time
 
Fecha de Ingreso: agosto-2008
Ubicación: $MX->Gto['León'];
Mensajes: 10.106
Antigüedad: 15 años, 8 meses
Puntos: 2237
Respuesta: Duda con join : (

Asi como estas haciendo la consulta buscas solo el nombre de usuario que corresponda a la id de campo1, si no se encuentra, entonces buscara el nombre de usuario que corresponda a la id del campo 2, NO estas pidiendo los dos nombres de usuario, sino UNO U OTRO.

Lo que necesitas es hacer un join a tabla2 con campo1 y otro a la misma tabla, pero con campo2 y, tal vez, obtener el resultado en una matriz numerica, en lugar de asociativa, para evitar que se sobreescriban los indices.
__________________
- León, Guanajuato
- GV-Foto
  #3 (permalink)  
Antiguo 23/02/2009, 15:51
 
Fecha de Ingreso: junio-2005
Mensajes: 343
Antigüedad: 18 años, 10 meses
Puntos: 10
Respuesta: Duda con join : (

La consulta sería la siguiente:

select v1.nombreusuario,v2.nombreusuario
from tabla1
left join tabla2 v1 ON (tabla1.campo1 = v1.idusuario)
left join tabla2 v2 ON (tabla1.campo2 = v2.idusuario)

Con esto sacas los dos nombres de la base de datos.
  #4 (permalink)  
Antiguo 24/02/2009, 12:04
 
Fecha de Ingreso: agosto-2008
Mensajes: 166
Antigüedad: 15 años, 8 meses
Puntos: 1
Respuesta: Duda con join : (

Buenas tardes, muchas gracias a ambos.

Parece que medio me funciona bien con lo que me has puesto jorgivaz, el caso es que no estoy familiarizado con los alias y no sé muy bien como funcionan. Te comento esto porque así obtengo el nombre de los usuarios, pero en el echo no consigo que salgan todos. Es decir, al hacer lo siguiente:

while($row = mysql_fetch_array($querydb)) {
echo $row['nombreusuario'];
echo "<br>";
}
Me sale sólo el nombre del usuario obtenido con el segundo left join, es decir, de cada registro de la tabla1, sólo me saca el usuario que se encuentra en el Campo2. ¿Cómo puedo sacar también los otros?

Mil gracias y un saludo.
  #5 (permalink)  
Antiguo 24/02/2009, 15:52
 
Fecha de Ingreso: junio-2005
Mensajes: 343
Antigüedad: 18 años, 10 meses
Puntos: 10
Respuesta: Duda con join : (

$sql = "select v1.nombreusuario as nombre_1,v2.nombreusuario as nombre_2
from tabla1
left join tabla2 v1 ON (tabla1.campo1 = v1.idusuario)
left join tabla2 v2 ON (tabla1.campo2 = v2.idusuario)";

...
...

while($row = mysql_fetch_array($querydb)) {
echo $row['nombre_1'].' vs '.$row['nombre_2'];
echo "<br>";
}
  #6 (permalink)  
Antiguo 01/03/2009, 15:53
 
Fecha de Ingreso: agosto-2008
Mensajes: 166
Antigüedad: 15 años, 8 meses
Puntos: 1
Respuesta: Duda con join : (

Buenas,

Lo primero disculpas por retomar un tema "zanjado". Si acaso jorgivaz se acuerda un poco de qué iba el tema, te agradecería un último apaño, y ya no habrán más jeje. Si te resulta pesado retomarlo ya lo explicaré de 0.

Ahora lo que necesito es también recoger los idusuario que hemos utilizado para hacer el left join. Es decir, cuando haga el while:

while($row = mysql_fetch_array($querydb)) {
echo $row['nombre_1'].' vs '.$row['nombre_2'];
echo "<br>";
}

Necesito también recoger aparte del nombre de los usuarios, el id de los mismos, en ese mismo while. ¿Cómo tengo que hacer la consulta?

Gracias y un saludo.
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 10:23.