Foros del Web » Programando para Internet » PHP »

Problemas para imprimir datos de consulta

Estas en el tema de Problemas para imprimir datos de consulta en el foro de PHP en Foros del Web. hola tengo un problema... si tengo esta consulta SELECT i.id , c.id_inventario , m.id_inventario FROM inventario i INNER JOIN inventario_cpu c ON i.id_cpu = c.id_inventario ...
  #1 (permalink)  
Antiguo 12/06/2008, 05:27
(Desactivado)
 
Fecha de Ingreso: enero-2008
Ubicación: Mendoza
Mensajes: 458
Antigüedad: 16 años, 2 meses
Puntos: 2
Exclamación Problemas para imprimir datos de consulta

hola tengo un problema...

si tengo esta consulta

SELECT i.id , c.id_inventario , m.id_inventario
FROM inventario i
INNER JOIN inventario_cpu c ON i.id_cpu = c.id_inventario
INNER JOIN inventario_monitor m ON i.id_monitor = m.id_inventario

donde en la tabla inventario_cpu y en la tabla inventario_monitor tengo un campo de nombre id_inventario... la consulta funciona bien, pero a la hora de mostrar los resultados me complico..

Como hago para mostrar el campo id_inventario de las dos tablas ya que si lo llamo asi:

while ( $array=mysql_fetch_array($consulta) ) {
echo "ID INVENTARIO: ".$array[id]."<br>";
echo "INVENTARIO CPU: ".$array[id_inventario]."<br>";
echo "INVENTARIO MONITOR: ".$array[id_inventario]."<br>";
}

Me toma el del primer campo declarado... y al segundo no....

Ayuda plisssss

Ayuda plissssssssssssss
  #2 (permalink)  
Antiguo 12/06/2008, 05:52
Avatar de Tokkara  
Fecha de Ingreso: junio-2008
Mensajes: 131
Antigüedad: 15 años, 10 meses
Puntos: 5
Respuesta: Problemas para imprimir datos de consulta

Hola buenas. Asignale un nombre distinto al campo m.id_inventario

Código PHP:
"SELECT i.id , c.id_inventario , m.id_inventario AS id2
FROM inventario i
INNER JOIN inventario_cpu c ON i.id_cpu = c.id_inventario
INNER JOIN inventario_monitor m ON i.id_monitor = m.id_inventario"

//---Ahora el campo m.id_inventario se llama id2

while ( $array=mysql_fetch_array($consulta) ) {
echo 
"ID INVENTARIO: ".$array['id']."<br>";
echo 
"INVENTARIO CPU: ".$array['id_inventario']."<br>";
echo 
"INVENTARIO MONITOR: ".$array['id2']."<br>";

Prueba asi.
saludos
  #3 (permalink)  
Antiguo 12/06/2008, 06:11
(Desactivado)
 
Fecha de Ingreso: enero-2008
Ubicación: Mendoza
Mensajes: 458
Antigüedad: 16 años, 2 meses
Puntos: 2
Exclamación Respuesta: Problemas para imprimir datos de consulta

Me tira error en la consulta de esa forma...

SELECT i.id , c.id_inventario , m.id_inventario AS idmonitor
FROM inventario i
INNER JOIN inventario_cpu c ON i.id_cpu = c.id_inventario
INNER JOIN inventario_monitor m ON i.id_monitor = m.idmonitor

Warning: mysql_fetch_array(): supplied argument is not a valid MySQL result resource in C:\servidor\web\help_desk\libreria\listados.php on line 6

Lo que tengo en la linea 6 es:

while ( $array=mysql_fetch_array($consulta) ) {
echo "ID PUESTO: ".$array[id]."<br>";
echo "INVENTARIO CPU: ".$array[id_cpu]."<br>";
echo "INVENTARIO MONITOR: ".$array[id_monitor]."<br>";
}

Me fije bien todo y es problema de la consulta.....

Otra cosa, antes de que le asigne un nombre al campo me hacia una cosa rara... cuando hacia la consulta de la siguiente manera:

SELECT i.id , c.id_cpu , m.id_monitor , p.id_impresora
FROM inventario i
INNER JOIN inventario_cpu c ON i.id_cpu = c.id_inventario
INNER JOIN inventario_monitor m ON i.id_monitor = m.idmonitor
INNER JOIN inventario_impresora p ON i.id_impresora = p.id_impresora

Se me cuelga la PC..... ( Por que puede llegar a ocurrir esto... ) probe varias veces y siempre se me colgo...

Saludos
  #4 (permalink)  
Antiguo 12/06/2008, 10:00
Avatar de GatorV
$this->role('moderador');
 
Fecha de Ingreso: mayo-2006
Ubicación: /home/ams/
Mensajes: 38.567
Antigüedad: 17 años, 10 meses
Puntos: 2135
Respuesta: Problemas para imprimir datos de consulta

Agrega un or die( mysql_error() ) para que veas el error de la consulta.

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 21:14.