Foros del Web » Programando para Internet » PHP »

no repetir una frase en una consulta

Estas en el tema de no repetir una frase en una consulta en el foro de PHP en Foros del Web. Bueno. Solucionado el tema anterior, ahora lo que quiero es lo siguiente. en la anterior consulta si recordáis obtenía las categorías que tenían asociadas subcategorias. ...
  #1 (permalink)  
Antiguo 04/09/2008, 02:46
Avatar de estibaliz2006  
Fecha de Ingreso: noviembre-2006
Mensajes: 439
Antigüedad: 17 años, 5 meses
Puntos: 1
no repetir una frase en una consulta

Bueno. Solucionado el tema anterior, ahora lo que quiero es lo siguiente. en la anterior consulta si recordáis obtenía las categorías que tenían asociadas subcategorias. Al hacer click en la categoria en cuestión pues pasaba a otra fase donde se me muestran las subcategorias que esa categoria tiene asociadas.

os recuerdo la estructura de las tablas:

//////////////////////
Tabla categoria:

idcat
nombrecat

Tabla subcategoria

idsub
nombresub
catid----que es la categoria a la que pertenece

la consulta que realizo para sacar las subcategorias de esa categoría asociada es la siguiente:


Código PHP:
SELECT *

FROM categorias

INNER JOIN subcategorias

ON idcat= catid

WHERE idcat ='$id'

ORDER BY nombrecat ASC

donde el $id es el id pasado de la categoría en cuestión

El problema está en que yo quiero mostrar una frase antes del estilo:

LAS SUBCATEGORIAS ASOCIADAS A LA CATEGORIA $p[nombrecat] son:

$p[nombresub]

Así supongamos un ejemplo. yo he hecho click en la categoria PAPELERIA que tiene asociadas las subcategorias BOLIGRAFOS Y FOLIOS, los resultados de la consulta que hago me da lo siguiente:

/////////////////////////////
LAS SUBCATEGORIAS ASOCIADAS A LA CATEGORIA PAPELERIA son:
BOLIGRAFOS

LAS SUBCATEGORIAS ASOCIADAS A LA CATEGORIA PAPELERIA son:
FOLIOS
////////////////////////////

y así si hubiera más subcategorías pues me mostraría x veces esa frase delante de la subcategoria, cuando el resultado que yo busco es:

LAS SUBCATEGORIAS ASOCIADAS A LA CATEGORIA PAPELERIA son:
BOLIGRAFOS
FOLIOS

para mostrar los datos realizo lo siguiente:

Código PHP:
$id=$_GET['id'];
    
$sql =     "SELECT      *FROM     categorias INNER JOIN subcategorias        ON idcat= catid   WHERE     idcat ='$id'  ORDER BY    nombrecat ASC ";

$result mysql_query($sql);
$datosmysql_num_rows($result);

if(
$datos

        {
        
        while(
$p mysql_fetch_array($result)) 
            {
echo 
" Subcategorías asociadas a la categoría $p[nombrecat] son las siguientes:<br><br>";
            echo 
" $p[nombresub]<br>"
             
             }        }
      
mysql_free_result($result
Alguna idea de cómo solucionarlo?
  #2 (permalink)  
Antiguo 04/09/2008, 03:49
Avatar de Nlrvana  
Fecha de Ingreso: marzo-2008
Mensajes: 36
Antigüedad: 16 años, 1 mes
Puntos: 0
Respuesta: no repetir una frase en una consulta

Saca la frase del bucle:

Código PHP:
$id=$_GET['id'];
    
$sql =     "SELECT      *FROM     categorias INNER JOIN subcategorias        ON idcat= catid   WHERE     idcat ='$id'  ORDER BY    nombrecat ASC ";

$result mysql_query($sql);
$datosmysql_num_rows($result);

if(
$datos)

{

echo 
" Subcategorías asociadas a la categoría $p[nombrecat] son las siguientes:<br><br>";
        
        while(
$p mysql_fetch_array($result)) 
            {

            echo 
" $p[nombresub]<br>"
             
             }        }
      
mysql_free_result($result
  #3 (permalink)  
Antiguo 04/09/2008, 03:53
 
Fecha de Ingreso: septiembre-2008
Mensajes: 13
Antigüedad: 15 años, 8 meses
Puntos: 0
Respuesta: no repetir una frase en una consulta

1- Para que no te repita los registros x veces usa GROUP BY.
2- Para que no se te repita la frase tienes que sacarla del 'bucle' while.
  #4 (permalink)  
Antiguo 04/09/2008, 04:25
Avatar de estibaliz2006  
Fecha de Ingreso: noviembre-2006
Mensajes: 439
Antigüedad: 17 años, 5 meses
Puntos: 1
Respuesta: no repetir una frase en una consulta

si lo saco del bucle la variable $p[nombrecat] la devuelve vacía, es decir, devuelve:
LAS SUBCATEGORIAS ASOCIADAS A LA CATEGORIA son:
y la verdad no sé por qué porque la lógica es esa...ya lo había hecho antes de plantear aquí la consulta...de hecho por eso la planteé...

la opción de GROUP BY no es válida porque entonces me realizará lo siguiente:

LAS SUBCATEGORIAS ASOCIADAS A LA CATEGORIAS PAPELERIA SON:
BOLIGRAFOS

es decir, sólo me saca una única subcategoría....

qué está pasando?
  #5 (permalink)  
Antiguo 04/09/2008, 05:06
 
Fecha de Ingreso: septiembre-2008
Mensajes: 13
Antigüedad: 15 años, 8 meses
Puntos: 0
Respuesta: no repetir una frase en una consulta

Código PHP:
<?PHP  
print "Subcategorías asociadas a la categoría";
        while(
$p mysql_fetch_array($result)){ 
        print 
$p['nombrecat']; ?> 
        Son las siguientes:<br /><br />
          <?PHP   
        
print $p['nombresub'];  
         } 
?>
prueba esto,

Y para que no se te repitan los registros puedes cambiar la consulta te propongo lo siguiente:

SELECT idcat, nombrecat, subcategorias.catid, subcategoria.nombresub
FROM categorias,subcategorias
WHERE categorias.idcat=subcategorias.catid
AND categorias.idcat ='$id'
GROUP BY nombrecat ASC;

Dime si te funciona

Última edición por G0L3M; 04/09/2008 a las 05:15
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 07:03.