Foros del Web » Programando para Internet » PHP »

Cómo puedo mostrar un solo dato de una tabla relacionada?

Estas en el tema de Cómo puedo mostrar un solo dato de una tabla relacionada? en el foro de PHP en Foros del Web. Hola a todos! Tengo una duda con respecto a mostrar datos desde una bd. El tema es el siguiente... Tengo 2 tablas: tabla propiedades ----------------------- ...
  #1 (permalink)  
Antiguo 26/10/2010, 11:14
 
Fecha de Ingreso: mayo-2002
Ubicación: Capital Federal
Mensajes: 630
Antigüedad: 21 años, 11 meses
Puntos: 1
Cómo puedo mostrar un solo dato de una tabla relacionada?

Hola a todos! Tengo una duda con respecto a mostrar datos desde una bd. El tema es el siguiente...
Tengo 2 tablas:

tabla propiedades
-----------------------
id_propiedad
cod_propiedad
id_tipopropiedad
detalles_propiedad

tabla fotos
----------------------
id_foto
foto
cod_propiedad

En la tabla FOTOS cargo todas las fotos y las relaciono con el cod_propiedad que es UNICO en la tabla propiedades y que sería así (ej: CAS001, DEP001, etc) Cada uno de ellos equivale a una propiedad a mostrar.

Mi consulta actual para listar es la siguiente:
Código PHP:
// id_tipopropiedad es por ej.: 1-casas, 2-departamentos...
$result mysql_query("SELECT * FROM propiedades, tipopropiedad 
WHERE propiedades.id_tipopropiedad = tipopropiedad.id_tipopropiedad 
AND propiedades.id_tipopropiedad = $id_tipopropiedad 
ORDER BY propiedades.id_propiedad"
$con); 
Y lo muestro así:
Código PHP:
<? if (mysql_num_rows($result) > 0) {

while (
$row mysql_fetch_array($result)) {   ?>
  <tr>
    <td><? echo $row['desc_tipopropiedad'];?></td>
    <td><? echo $row['desc_operacion'];?></td>
    <td><? echo $row['cod_propiedad'];?></td>
    </tr>
  <tr>
    <td</td>
  </tr>
  <?
    
}//fin del while
    
}else{
    
//no hay resultados
?>
  <tr>
    <td><? echo "No se encontraron datos cargados"?></td>
  </tr>
      <?  
    
}
?>
Si selecciono id_tipopropiedad = 1, me lista todas las propiedades correspondientes con sus respectidos detalles y sería así:
CAS001
CAS002
CAS003
......

Lo que yo quisiera hacer es relacionar la tabla propiedades con la tabla fotos para que en este listado aparezca el debajo del cod_propiedad UNA SOLA FOTO y no TODAS de la tabla FOTOS, que se corresponda al cod_propiedades, por supuesto.

¿Cómo se puede hacer?

Muchas gracias por su atención y saludos.

Marx.
__________________
"Todo lo que somos es el resultado de lo que hemos pensado". Budda.
  #2 (permalink)  
Antiguo 26/10/2010, 13:00
Avatar de gogupe  
Fecha de Ingreso: octubre-2006
Ubicación: Mallorca
Mensajes: 897
Antigüedad: 17 años, 6 meses
Puntos: 32
Respuesta: Cómo puedo mostrar un solo dato de una tabla relacionada?

Hola antes que nada, tendrías que relacionar las dos tablas por el campo en común de la siguiente forma:

Código:
SELECT * FROM propiedades INNER JOIN fotos ON propiedades.cod_propiedad=fotos.cod_propiedad WHERE ...
Escribe tu luego todo lo que viene después del WHERE.

Pruébalo así a ver que te sale
  #3 (permalink)  
Antiguo 28/10/2010, 07:07
 
Fecha de Ingreso: mayo-2002
Ubicación: Capital Federal
Mensajes: 630
Antigüedad: 21 años, 11 meses
Puntos: 1
Respuesta: Cómo puedo mostrar un solo dato de una tabla relacionada?

Hola y gracias por responder, pero me salió un error.

"You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'ORDER BY propiedades.id_propiedad' at line 1 "

La consulta completa que ejecuté es esta:

Código PHP:
$result mysql_query("SELECT * FROM propiedades, tipopropiedad, operacion 
INNER JOIN fotospropiedades ON propiedades.cod_propiedad = fotospropiedades.cod_propiedad 
WHERE propiedades.id_tipopropiedad = tipopropiedad.id_tipopropiedad 
AND propiedades.id_operacion = operacion.id_operacion 
AND propiedades.id_tipopropiedad = $id_tipopropiedad 
ORDER BY propiedades.id_propiedad"
$con) or die(mysql_error()); 
Le saqué el ORDER BY y me tiró este error:

"You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '' at line 1 "

Me podrían decir dónde estoy haciendo mal la consulta?

Muchas gracias.
__________________
"Todo lo que somos es el resultado de lo que hemos pensado". Budda.
  #4 (permalink)  
Antiguo 28/10/2010, 07:24
Avatar de Carlojas  
Fecha de Ingreso: junio-2007
Ubicación: Shikasta
Mensajes: 1.272
Antigüedad: 16 años, 10 meses
Puntos: 49
Respuesta: Cómo puedo mostrar un solo dato de una tabla relacionada?

Que tal marx-pola, prueba tu consulta de la siguiente manera:
Código PHP:
Ver original
  1. $result = mysql_query("SELECT * FROM propiedades  
  2. INNER JOIN fotospropiedades ON propiedades.cod_propiedad = fotospropiedades.cod_propiedad
  3. INNER JOIN tipopropiedad ON propiedades.id_tipopropiedad = tipopropiedad.id_tipopropiedad
  4. INNER JOIN operacion ON propiedades.id_operacion = operacion.id_operacion
  5. WHERE propiedades.id_tipopropiedad = $id_tipopropiedad
  6. ORDER BY propiedades.id_propiedad", $con) or die(mysql_error());


Saludos.
__________________
"SELECT * FROM Mujeres WHERE situacion NOT IN ('CASADAS','CON HIJOS','ATORMENTADAS','CUASI-ENNOVIADAS') AND personalidad <> 'INTENSA'"
  #5 (permalink)  
Antiguo 28/10/2010, 08:22
 
Fecha de Ingreso: mayo-2002
Ubicación: Capital Federal
Mensajes: 630
Antigüedad: 21 años, 11 meses
Puntos: 1
Respuesta: Cómo puedo mostrar un solo dato de una tabla relacionada?

Gracias Carlojas. Ahora no me aparece el error y me muestra el listado, pero al ejecutar la consulta, el WHILE que genera dicho listado, me muestra TODAS las fotos de la tabla FOTOSPROPIEDADES... o sea que me aparece así (debajo de cada foto le agregué el cod. de la propiedad):

FOTO1
CASA001
----------
FOTO2
CASA001
----------
FOTO3
CASA001
----------
FOTO1
CASA002
----------
FOTO2
CASA002
----------

Y lo que estoy tratando de hacer es que quede de esta manera:

FOTO1
CASA001
----------
FOTO1
CASA002
----------
FOTO1
CASA003
----------

De esta manera muestro el listado:
Código PHP:
<? if (mysql_num_rows($result) > 0) {

while (
$row mysql_fetch_array($result)) {   ?>
  <tr>
    <td><? echo $row['desc_tipopropiedad'];?></td>
    <td><? echo $row['desc_operacion'];?></td>
    <td><? echo $row['cod_propiedad'];?></td>
    </tr>
  <tr>
    <td</td>
  </tr>
  <?
    
}//fin del while
    
}else{
    
//no hay resultados
?>
  <tr>
    <td><? echo "No se encontraron datos cargados"?></td>
  </tr>
      <?  
    
}
?>
Tendría que ver que de alguna manera, la consulta SIEMPRE tome de la tabla FOTOSPROPIEDADES, la PRIMER foto RELACIONADA con el código propiedades.cod_propiedad.
¿Por qué es necesario? Porque en el caso que se elimine esa foto, si hay otra que corresponda al mismo cod_propiedad debería reemplazarla en el listado.

PD: Ah! detalle importante Carlojas. Me dí cuenta de algo en esta consulta que me has mostrado. En el caso que en la tabla FOTOSPROPIEDADES no se haya cargado ninguna foto, el while me devuelve cero y debería mostrar aunque sea los datos de la tabla PROPIEDADES. Calculo que no está tomando la variable del WHERE.

Nuevamente, mil gracias por la paciencia y por enseñarme nuevas opciones.

Saludos. Marx.
__________________
"Todo lo que somos es el resultado de lo que hemos pensado". Budda.

Última edición por marx-pola; 28/10/2010 a las 08:43
  #6 (permalink)  
Antiguo 01/11/2010, 07:58
 
Fecha de Ingreso: mayo-2002
Ubicación: Capital Federal
Mensajes: 630
Antigüedad: 21 años, 11 meses
Puntos: 1
Respuesta: Cómo puedo mostrar un solo dato de una tabla relacionada?

Bueno... aparentemente el tema de mostrar una sola imagen estaba en la línea del ORDER BY propiedades.id_propiedad.

Probé haciendo GROUP BY fotospropiedades.cod_propiedad y al eliminar la primer foto es reemplazada por la segunda que esté asociada por su cod_propiedad.

Por lo menos en mi amado Firefox funciona de maravillas... pero en la porquería de explorer no lo toma de una y hay que resetearlo muchas veces o borrar el caché para que aparezca.
__________________
"Todo lo que somos es el resultado de lo que hemos pensado". Budda.

Etiquetas: dato, tablas
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 06:49.