Foros del Web » Programando para Internet » PHP »

Mostrar productos desde la categoria correspondiente PHP MYSQL

Estas en el tema de Mostrar productos desde la categoria correspondiente PHP MYSQL en el foro de PHP en Foros del Web. Hola a todos, Hace un par de días decidí hacer un catálogo Web, algo sencillo, “digamos”. Un catálogo que muestre las categorías con su respectivo ...
  #1 (permalink)  
Antiguo 10/11/2010, 22:10
 
Fecha de Ingreso: octubre-2010
Mensajes: 6
Antigüedad: 13 años, 6 meses
Puntos: 0
Pregunta Mostrar productos desde la categoria correspondiente PHP MYSQL

Hola a todos,
Hace un par de días decidí hacer un catálogo Web, algo sencillo, “digamos”. Un catálogo que muestre las categorías con su respectivo enlace y desde allí, ir a los productos que pertenecen a una categoría, conseguí hacer lo del carrito para seleccionar productos y luego mandarlos por email, para solicitar un presupuesto, pero el problema es que me he quedado atascado en la siguiente parte, soy nuevo en PHP y MySQL con lo cual, intento asumir retos asequibles. Ya no se si esto que es os voy a plantear es mas complejo de lo que yo pensaba?

Tengo una base de datos con 2 tablas, categorías y productos:

CREATE TABLE `categorias` (
`id` int(11) NOT NULL auto_increment,
`nombre` varchar(255) NOT NULL,
`imagen` blob NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;

CREATE TABLE `productos` (
`id` int(11) auto_increment,
`ref` varchar(90) NOT NULL,
`nombre` varchar(255) NOT NULL,
`categoria` varchar(255) NOT NULL,
`idcategorias` int(11) NOT NULL,
`producto_descripcion` text NOT NULL,
`producto_imagen` blob NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;

En categorias.php tengo el siguiente código, por supuesto, he omitido la parte de conexión a la base de datos:


$columns = 3;

$query = "SELECT id, nombre, imagen FROM categorias WHERE nombre is not null ORDER BY nombre ASC";
$result = mysql_query($query);
$num_rows = mysql_num_rows($result);

echo "<table width=\"70%\" align=\"center\" border=\"0\" cellpadding=\"21\" cellspacing=\"6\">\n";
for($i = 0; $i < $num_rows; $i++) {
$row = mysql_fetch_array($result);
if($i % $columns == 0) {

echo "<tr>\n";
}
echo "<td width='35%'><span class='titulo'>$row[nombre]</span><br>
<div aling='left' class='presupuesto'><a href='agregacar.php?$SID&id=$row[id]'>Presupuesto</a><img src='images/$row[imagen]'><br>

//Aquí tengo el enlace a productos
<a href='productos.php?id=$row[id]&categoria=$row[categoria]'>
$row[nombre] Ver</a></div></td>\n";

if(($i % $columns) == ($columns - 1) || ($i + 1) == $num_rows) {
echo "</tr>\n";
}
}

echo "</table>\n";

Con este código muestro las categorias que tengo en mi base de datos, funciona bien, pero, no consigo enlazar, vincular correctamente con productos:

Es decir: productos.php?id=27 y que me muestre los productos pertenecientes a la categoría con ese id. Entiendo que mis tablas tienen que estar interrelacionadas, pero ya no se si lo que hago mal es la consulta?

Aquí dejo el código de productos.php, por cierto la respuesta que tengo aquí es
Query was empty, de ahí que sospeche que no hago bien la consulta.


$columns = 2;
$query = "SELECT id, ref, nombre, categoria, idcategoria, producto_desccripcion FROM productos WHERE nombre is not null ORDER BY nombre ASC";
$result = mysql_query($query);
mysql_query($result) or die(mysql_error());
$num_rows = mysql_num_rows($result);

echo "<table width=\"70%\" align=\"center\" border=\"0\" cellpadding=\"21\" cellspacing=\"6\">\n";
for($i = 0; $i < $num_rows; $i++) {
$row = mysql_fetch_array($result);
if($i % $columns == 0) {
echo "<tr>\n";
}

echo "<td width='35%'><span class='titulo'>$row[ref]</span><br><span class='titulo'>$row[nombre]</span><br>
<span class='titulo'>$row[categoria]</span><br><span class='titulo'>$row[idcategoria]</span><br>
<span class='titulo'>$row[producto_descripcion]</span><br>

<div aling='left' class='presupuesto'><a href='agregacar.php?$SID&id=$row[id]'>Presupuesto</a>
<img src='images/$row[producto_imagen]'><br>

<a href='productos.php?productos_id=".$row['productos_id']."'>Ver</a></div>

</td>\n";

if(($i % $columns) == ($columns - 1) || ($i + 1) == $num_rows)
{

echo "</tr>\n";
}
}
echo "</table>\n";


De ante mano gracias por vuestra ayuda.
Un saludo (=D)
  #2 (permalink)  
Antiguo 11/11/2010, 00:01
 
Fecha de Ingreso: noviembre-2004
Ubicación: NULL
Mensajes: 652
Antigüedad: 19 años, 5 meses
Puntos: 6
Respuesta: Mostrar productos desde la categoria correspondiente PHP MYSQL

tienes una ensalada ahi amigo usa "LEFT JOIN"
  #3 (permalink)  
Antiguo 11/11/2010, 00:50
 
Fecha de Ingreso: octubre-2010
Mensajes: 6
Antigüedad: 13 años, 6 meses
Puntos: 0
Respuesta: Mostrar productos desde la categoria correspondiente PHP MYSQL

Cita:
Iniciado por pilucho Ver Mensaje
tienes una ensalada ahi amigo usa "LEFT JOIN"
Si amigo, llevas razón, tengo una ensalada enorme. He estado mirado lo de utilizar LEFT JOIN, con tu sugerencia entiendo que me confirmas, que hago mal el SELECT desde productos.php? he intentado cambiar el SELECT incluyendo LEFT JOIN, pero no acabo de pillar el concepto, con lo cual me sigue dando como resultado: Query was empty. Si pudieras dar más detalles para confeccionar el SELECT te lo agradecería.

Un abrazo.
  #4 (permalink)  
Antiguo 11/11/2010, 01:35
 
Fecha de Ingreso: noviembre-2004
Ubicación: NULL
Mensajes: 652
Antigüedad: 19 años, 5 meses
Puntos: 6
Respuesta: Mostrar productos desde la categoria correspondiente PHP MYSQL

Prueba asi


Código PHP:

<?
$columns 
3;

//$query = "SELECT id, nombre, imagen FROM categorias WHERE nombre is not null ORDER BY nombre ASC";
$query "SELECT * FROM productos LEFT JOIN categorias ON productos.id=categorias.id WHERE nombre='$nombre'";

$result mysql_query($query);
$num_rows mysql_num_rows($result);

echo 
"<table width=\"70%\" align=\"center\" border=\"0\" cellpadding=\"21\" cellspacing=\"6\">\n";
for(
$i 0$i $num_rows$i++) {
$row mysql_fetch_array($result);
if(
$i $columns == 0) {

echo 
"<tr>\n";
}
echo 
"<td width='35%'><span class='titulo'>$row[nombre]</span><br>
<div aling='left' class='presupuesto'><a href='agregacar.php?$SID&id=$row[id]'>Presupuesto</a><img src='images/$row[imagen]'><br>

// Aquí tengo el enlace a productos
<a href='productos.php?id=$row[id]&categoria=$row[categoria]'>
$row[nombre] Ver</a></div></td>\n"
;

if((
$i $columns) == ($columns 1) || ($i 1) == $num_rows) {
echo 
"</tr>\n";
}
}
echo 
"</table>\n";


$columns 2;
//$query = "SELECT id, ref, nombre, categoria, idcategoria, producto_desccripcion FROM productos WHERE nombre is not null ORDER BY nombre ASC";
$query "SELECT * FROM productos WHERE nombre='$nombre'";

$result mysql_query($query);
mysql_query($result) or die(mysql_error()); 
$num_rows mysql_num_rows($result);

echo 
"<table width=\"70%\" align=\"center\" border=\"0\" cellpadding=\"21\" cellspacing=\"6\">\n";
for(
$i 0$i $num_rows$i++) {
$row mysql_fetch_array($result);
if(
$i $columns == 0) {
echo 
"<tr>\n";
}

echo 
"<td width='35%'><span class='titulo'>$row[ref]</span><br><span class='titulo'>$row[nombre]</span><br>
<span class='titulo'>$row[categoria]</span><br><span class='titulo'>$row[idcategoria]</span><br>
<span class='titulo'>$row[producto_descripcion]</span><br>

<div aling='left' class='presupuesto'><a href='agregacar.php?$SID&id=$row[id]'>Presupuesto</a>
<img src='images/$row[producto_imagen]'><br>

<a href='productos.php?id="
.$row['id']."'>Ver</a></div>

</td>\n"
;

if((
$i $columns) == ($columns 1) || ($i 1) == $num_rows
{

echo 
"</tr>\n"
}
}
echo 
"</table>\n";



?>






















Cita:
SUGERENCIA: Solo si quieres trabajar ordenado

Cambia esto:


CREATE TABLE `categorias` (
`id` int(11) NOT NULL auto_increment,
`nombre` varchar(255) NOT NULL,
`imagen` blob NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;

CREATE TABLE `productos` (
`id` int(11) auto_increment,
`ref` varchar(90) NOT NULL,
`nombre` varchar(255) NOT NULL,
`categoria` varchar(255) NOT NULL,
`idcategorias` int(11) NOT NULL,
`producto_descripcion` text NOT NULL,
`producto_imagen` blob NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;



Por esto:

CREATE TABLE `categorias` (
`idcategorias` int(11) NOT NULL auto_increment,
`nombre` varchar(255) NOT NULL,
`imagen` blob NOT NULL,
PRIMARY KEY (`idcategorias`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;

CREATE TABLE `productos` (
`id` int(11) auto_increment,
`ref` varchar(90) NOT NULL,
`nombre` varchar(255) NOT NULL,
`categoria` varchar(255) NOT NULL,
`idcategorias` int(11) NOT NULL,
`producto_descripcion` text NOT NULL,
`producto_imagen` blob NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;
  #5 (permalink)  
Antiguo 11/11/2010, 09:54
 
Fecha de Ingreso: octubre-2010
Mensajes: 6
Antigüedad: 13 años, 6 meses
Puntos: 0
Respuesta: Mostrar productos desde la categoria correspondiente PHP MYSQL

Muchas gracias pilucho por tu respuesta, pero ahora no me muestra las categorias, es decir que no ejecuta la consulta, solo indexa la plantilla sin contenido,.. seguire estudiando, a ver si doy con la solución, no pense que fuera tan dificil mostrar simplemente el contenido de una tabla desde un enlace,.. No lo entiendo,..


Categoria A --------> productos A
Categoria B --------> productos B

Un saludo.

Etiquetas: mysql, productos, categorias
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 09:34.