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, Hace un tiempo plantee una duda en el foro acerca de un join, que me resolvieron perfectamente. Ahora necesito una pequeña "ampliación" de ...
  #1 (permalink)  
Antiguo 06/04/2009, 12:49
 
Fecha de Ingreso: agosto-2008
Mensajes: 166
Antigüedad: 15 años, 8 meses
Puntos: 1
Duda con join

Buenas tardes,

Hace un tiempo plantee una duda en el foro acerca de un join, que me resolvieron perfectamente. Ahora necesito una pequeña "ampliación" de ese join, y sintiéndolo mucho no tengo ni la más remota idea jeje. Os pongo en situación:

Se trata de una búsqueda a una base de datos, de unos registros de este tipo (en los campos rival1 y rival2 están registrados unos ID.:
Tabla1:
rival1: 45682
rival2: 45963

Y el join me une los ID, con el nombre de usuario que corresponda, de la tabla de usuarios:

$querydb4 = mysql_query("select v1.nomusuario AS rival1,v2.nomusuario AS rival2 from dbpeleas LEFT JOIN dbusuarios v1 ON (dbpeleas.rival1=v1.idusuario) LEFT JOIN dbusuarios v2 ON (dbpeleas.rival2=v2.idusuario)");

De forma que con un while, obtengo los nombres de los usuarios según emparejamientos:
Para el ejemplo, me sacaría los nombres de los usuarios 45682 y 45963. (Pepe vs Antonio)

Pues bien, ahora lo que necesito, es que a la vez que obtengo los nombres de esos usuarios, que en el mismo while obtenga su id. Será de lo más sencillo pero no tengo ni idea de como hacerlo. Aunque no venga al caso, el while actualmente es así:

while($row4 = mysql_fetch_array($querydb4)) {

echo $row4['rival1']; // Aquí querría también obtener el id del rival1
echo " vs ";
echo $row4['rival2']; // Y aquí obtener el del rival2
echo "<br>";
}


Espero haberme explicado bien.... Cualquier aclaración no dudeis en consultarme, y mil gracias!!
  #2 (permalink)  
Antiguo 06/04/2009, 12:52
Avatar de David
Moderador
 
Fecha de Ingreso: abril-2005
Ubicación: In this planet
Mensajes: 15.720
Antigüedad: 19 años
Puntos: 839
Respuesta: Duda con join

Sólo tienes que agregar a la selección de campos esos campos:
Código sql:
Ver original
  1. SELECT dbpeleas.rival1 r1, dbpeleas.rival2 r2, ...
Y obtenerlos con los índices 'r1' y 'r2'
__________________
Por favor, antes de preguntar, revisa la Guía para realizar preguntas.
  #3 (permalink)  
Antiguo 06/04/2009, 12:54
Avatar de Synkronice  
Fecha de Ingreso: octubre-2007
Ubicación: Madrid
Mensajes: 831
Antigüedad: 16 años, 6 meses
Puntos: 48
Respuesta: Duda con join

1- Te recomiendo el foro de bases de datos para estas consultas.
2- Para tener disponible un campo tras una consulta, has de incluir ese campo en la claúsula SELECT.
3- Si facilitaras la estrucutura de todas las tablas que intervienen en la query se te podría ayudar mejor.

Saludos!
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 01:35.