Foros del Web » Programando para Internet » PHP »

URGENTE: Problema lógico que no he podido resolver (PHP-MySQL)

Estas en el tema de URGENTE: Problema lógico que no he podido resolver (PHP-MySQL) en el foro de PHP en Foros del Web. Hola amigos, tanto tiempo de no andar por estos lados. Bueno, la verdad debo recurrir nuevamente a los foros porque tengo una duda que no ...
  #1 (permalink)  
Antiguo 31/08/2007, 21:52
Avatar de NacHox  
Fecha de Ingreso: enero-2005
Mensajes: 25
Antigüedad: 19 años, 3 meses
Puntos: 1
URGENTE: Problema lógico que no he podido resolver (PHP-MySQL)

Hola amigos, tanto tiempo de no andar por estos lados.

Bueno, la verdad debo recurrir nuevamente a los foros porque tengo una duda que no he podido resolver y necesito seguir avanzando en lo que estoy haciendo.

Resulta que tengo un sitio web de rooms, donde en la página principal voy a mostrar un recuadro de los ultimos 6 rooms añadidos (un recuadro x cada room). Pasa, que en ese recuadro de cada room debe aparecer la categoría a la cual pertenece un room, pero no logro hacer la asociacion de las tablas.

Por un lado tengo una tabla categorias_rooms donde están todas las categorias con sus nombres y sus id repectivos. Por otro lado tengo la tabla rooms donde en el campo "categoria" sale por ejemplo el valor "1" que es el id de la categoria a la cual pertenece el juego.

Entonces, como lo hago para que en la principal me diga por ejemplo:

Nombre Juego: XXXXXX
Categoria: Nintendo DS --> esto es lo que no logro hacer, porque me sale el valor ej: 1, que es la asociacion a la categoria que pertenece (que esta en otra tabla).

No puedo agregar una consulta WHILE porque imaginen que en la principal el visitante no ha entrado a ninguna categoria especifica como para pasarle via URL algo como idcat=1 y que ahí si se pueda mostrar el nombre de la categoria a la cual pertenece el room.

Se entiende el problema?? Espero que sí pues necesito resolver esto pronto.

De antemano gracias a los que lean, y un millón de gracias a quien me pueda responder algo.

Nacho.
  #2 (permalink)  
Antiguo 31/08/2007, 22:27
Avatar de ginitofl  
Fecha de Ingreso: diciembre-2006
Ubicación: Lima Perú
Mensajes: 349
Antigüedad: 17 años, 4 meses
Puntos: 22
Re: URGENTE: Problema lógico que no he podido resolver (PHP-MySQL)

Hola Nacho muestra el codigo donde estas mostrando ahora esos 6 ultimos rooms y asi podre ayudarte.

Saludos
  #3 (permalink)  
Antiguo 31/08/2007, 22:34
Avatar de NacHox  
Fecha de Ingreso: enero-2005
Mensajes: 25
Antigüedad: 19 años, 3 meses
Puntos: 1
Re: URGENTE: Problema lógico que no he podido resolver (PHP-MySQL)

Lo tengo dentro de una función que hice, ojalá puedas ayudarme y pillar donde está mi error lógico:

Código PHP:
<?php

function ultimasNovedades(){

$link=Conectarse();

$sql=mysql_query("SELECT * FROM rooms ORDER BY rid DESC LIMIT 6",$link);
while(
$row=mysql_fetch_array($sql)){

$sql_uno=mysql_query("SELECT * FROM categorias_rooms WHERE rcid=$row[categoria]",$link);
while(
$row1=mysql_fetch_array($sql_uno)){

$ncat=$row1[nombre];
$rcid=$row1[rcid];

$rid=$row[rid];
$nombre=$row[titulo];
$ndesc=$row[hits];
$imagen=$row[imagen];
$cat=$row1[rcid];
$gen=$row[genero];
$lang=$row[idioma];
$sist=$row[sistema];
$peso=$row[peso];
$elink=$row[elink];
$directa=$row[directa];
$torrent=$row[torrent];

echo
"<table border='0' width='71%' cellspacing='0' cellpadding='0'>
  <tr>
    <td width='100%'>
      <table border='0' width='100%' cellspacing='1' cellpadding='0'>
        <tr>
          <td width='100%' colspan='2'>
            <p align='center'>$nombre</td>
        </tr>
        <tr>
          <td width='41%' valign='top'>
            <p align='center'><img border='0' src='$row[imagen]' width='200' height='200'></td>
          <td width='59%' valign='top'>
            <table border='0' width='100%' cellspacing='1' cellpadding='0'>
              <tr>
                <td width='100%'>Nº Descargas: $ndesc</td>
              </tr>
              <tr>
                <td width='100%'>Categoría: $cat</td>
              </tr>
              <tr>
                <td width='100%'>Género: $gen</td>
              </tr>
              <tr>
                <td width='100%'>Sistema: $sist</td>
              </tr>
              <tr>
                <td width='100%'>Idioma: $lang</td>
              </tr>
              <tr>
                <td width='100%'>Tamaño: $peso</td>
              </tr>
              <tr>
                <td width='100%'>
                  <p align='center'>Vía eLink: $elink</td>
              </tr>
              <tr>
                <td width='100%' align='center'>Descarga Directa: $directa</td>
              </tr>
              <tr>
                <td width='100%' align='center'>Vía Torrent: $torrent</td>
              </tr>
            </table>
          </td>
        </tr>
      </table>
    </td>
  </tr>
</table>"
;
} }

}

?>
De antemano, MUCHAS GRACIAS!
  #4 (permalink)  
Antiguo 31/08/2007, 22:47
Avatar de ginitofl  
Fecha de Ingreso: diciembre-2006
Ubicación: Lima Perú
Mensajes: 349
Antigüedad: 17 años, 4 meses
Puntos: 22
Re: URGENTE: Problema lógico que no he podido resolver (PHP-MySQL)

Hola Nacho no es necesario que hagas doble bucle por que no usas el INNER JOIN para esos caso siempre lo asi podrias reemplazar en ves de las dos consultas por esto:

SELECT *
FROM pedidos INNER JOIN clientes ON pedidos.clie = clientes.numclie


Código PHP:
$sql=mysql_query("SELECT * FROM rooms  INNER JOIN categorias_rooms ON rooms.categoria = categorias_rooms.rcid ORDER BY rooms.rid DESC LIMIT 6",$link); 
espero te sirva 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 04:13.