Foros del Web » Programando para Internet » PHP »

Consulta SQL complicada... AYUDA

Estas en el tema de Consulta SQL complicada... AYUDA en el foro de PHP en Foros del Web. Lo que intento hacer es una consulta relacional a mi BD a varias tablas En la primer consulta lo que hago es mostrar el nombre ...
  #1 (permalink)  
Antiguo 13/04/2008, 13:49
(Desactivado)
 
Fecha de Ingreso: enero-2008
Ubicación: Mendoza
Mensajes: 458
Antigüedad: 16 años, 2 meses
Puntos: 2
Consulta SQL complicada... AYUDA

Lo que intento hacer es una consulta relacional a mi BD a varias tablas

En la primer consulta lo que hago es mostrar el nombre del usuario...

En la segunda consulta lo que hago es mostrar de la tabla examen, la pregunta, la respuesta, lo que es correcto, lo que es incorrecto, y lo que respondio el usuario...

Bien, mi problema es el siguiente... como tengo varias respuestas para una sola pregunta, la consulta lo que me hace es traerme la pregunta, la respuesta, y demas...

y se me repepite asi:

Pregunta: Pregunta 8
Respuesta del usuario: Respuesta 1 de pregunta 8
Es Incorrecta

Pregunta: Pregunta 8
Respuesta del usuario: Respuesta 2 de pregunta 8
Es Incorrecta

Pregunta: Pregunta 7
Respuesta del usuario: Respuesta 1 de preg 1
Es Correcta

Pregunta: Pregunta 7
Respuesta del usuario: Otra respuesta para la 1
Es Correcta


Y lo que yo quiero es que se vea la pregunta, luego las respuestas a esa pregunta...

Y que no se me repita la pregunta varias veces.... si no... una sola vez cada pregunta...

Aqui posteo mi codigo...


Código PHP:

include("../../../../include/conexion.php");
conectar();

$iduser1;
$consulta mysql_query("SELECT DISTINCT e.iduser, a.nombre FROM examen e INNER JOIN alumno a ON e.iduser = a.iduser WHERE e.iduser = '$iduser' ORDER BY nombre ");
while (
$row=mysql_fetch_array($consulta))
            {

echo 
"".$row['nombre']."";

$con mysql_query("SELECT p.pregunta, r.respuesta, e.correcta, e.usuario, e.fecha, e.iduser FROM examen e INNER JOIN respuestas r ON e.idrespuesta =  r.idrespuesta INNER JOIN preguntas p ON p.idpregunta = r.idpregunta WHERE e.iduser=$iduser ");
$total_registros=mysql_num_rows($con);
while (
$p mysql_fetch_array($con)) 

{  
echo 
"".$p['pregunta']."<br />";
echo 
"".$p['respuesta']."<br />";
if (
$p['usuario']=="1") {
echo 
"Es Correcta";
} elseif (
$p['usuario']=="0") {
    echo 
"Es Incorrecta";
} else { 
    echo 
"No respondio";
    }
}  
}
desconectar();
?> 
Espero una ayudita de los maestros del php...

Graicas
  #2 (permalink)  
Antiguo 13/04/2008, 14:59
(Desactivado)
 
Fecha de Ingreso: enero-2008
Ubicación: Mendoza
Mensajes: 458
Antigüedad: 16 años, 2 meses
Puntos: 2
Pregunta Re: Consulta SQL complicada... AYUDA

Hola sigo probando, trate de hacerlo con mysql_fetch_assoc pero tampoco me dio resultado...

Una ayudita por aqui... plis...

Gracias
  #3 (permalink)  
Antiguo 13/04/2008, 18:34
 
Fecha de Ingreso: abril-2008
Mensajes: 613
Antigüedad: 16 años
Puntos: 22
Re: Consulta SQL complicada... AYUDA

Cita:
Iniciado por cmarrero Ver Mensaje
Lo que intento hacer es una consulta relacional a mi BD a varias tablas

En la primer consulta lo que hago es mostrar el nombre del usuario...

En la segunda consulta lo que hago es mostrar de la tabla examen, la pregunta, la respuesta, lo que es correcto, lo que es incorrecto, y lo que respondio el usuario...

Bien, mi problema es el siguiente... como tengo varias respuestas para una sola pregunta, la consulta lo que me hace es traerme la pregunta, la respuesta, y demas...

y se me repepite asi:

Pregunta: Pregunta 8
Respuesta del usuario: Respuesta 1 de pregunta 8
Es Incorrecta

Pregunta: Pregunta 8
Respuesta del usuario: Respuesta 2 de pregunta 8
Es Incorrecta

Pregunta: Pregunta 7
Respuesta del usuario: Respuesta 1 de preg 1
Es Correcta

Pregunta: Pregunta 7
Respuesta del usuario: Otra respuesta para la 1
Es Correcta


Y lo que yo quiero es que se vea la pregunta, luego las respuestas a esa pregunta...

Y que no se me repita la pregunta varias veces.... si no... una sola vez cada pregunta...

Aqui posteo mi codigo...


Código PHP:

include("../../../../include/conexion.php");
conectar();

$iduser1;
$consulta mysql_query("SELECT DISTINCT e.iduser, a.nombre FROM examen e INNER JOIN alumno a ON e.iduser = a.iduser WHERE e.iduser = '$iduser' ORDER BY nombre ");
while (
$row=mysql_fetch_array($consulta))
            {

echo 
"".$row['nombre']."";

$con mysql_query("SELECT p.pregunta, r.respuesta, e.correcta, e.usuario, e.fecha, e.iduser FROM examen e INNER JOIN respuestas r ON e.idrespuesta =  r.idrespuesta INNER JOIN preguntas p ON p.idpregunta = r.idpregunta WHERE e.iduser=$iduser ");
$total_registros=mysql_num_rows($con);
while (
$p mysql_fetch_array($con)) 

{  
echo 
"".$p['pregunta']."<br />";
echo 
"".$p['respuesta']."<br />";
if (
$p['usuario']=="1") {
echo 
"Es Correcta";
} elseif (
$p['usuario']=="0") {
    echo 
"Es Incorrecta";
} else { 
    echo 
"No respondio";
    }
}  
}
desconectar();
?> 
Espero una ayudita de los maestros del php...

Graicas

Hola,
Parece que has anidado 2 bucles y esto en realidad se debería poder hacer en una sola consulta y un sólo bucle utilizando las clausulas WHERE, GROUP y también poner cuídado al ORDER ya que puedes determinar con bastante exactitud la forma en que se mostrarán los registros mediante varios ORDER.

La sintaxis exacta habría que estudiarla y no será sencilla pero lo más óptimo es hacerlo en una sola consulta.
Sé que no te estoy dando la solución pero creo que es una pista de por dónde puede ir.
Saludos
  #4 (permalink)  
Antiguo 14/04/2008, 07:24
(Desactivado)
 
Fecha de Ingreso: enero-2008
Ubicación: Mendoza
Mensajes: 458
Antigüedad: 16 años, 2 meses
Puntos: 2
Re: Consulta SQL complicada... AYUDA

Bien, gracias por responder lo he solucionado de la siguiente forma...

Código PHP:
include("../../../../include/conexion.php");
conectar();

$iduser1;
$consulta mysql_query("SELECT DISTINCT e.iduser, a.nombre FROM examen e INNER JOIN alumno a ON e.iduser = a.iduser WHERE e.iduser = '$iduser' ORDER BY nombre ");
while (
$row=mysql_fetch_array($consulta))
            {

echo 
"".$row['nombre']."";

$con mysql_query("SELECT p.pregunta, r.respuesta, e.correcta, e.usuario, e.fecha, e.iduser FROM examen e INNER JOIN respuestas r ON e.idrespuesta =  r.idrespuesta INNER JOIN preguntas p ON p.idpregunta = r.idpregunta WHERE e.iduser=$iduser ORDER BY p.idpregunta");
$total_registros=mysql_num_rows($con);
$lp NULL;
while (
$p mysql_fetch_array($con))

{  
if(
$p['pregunta']!=$lp){
echo 
"<br><br>".$p['pregunta']."<br />";
$lp $p['pregunta'];
}
echo 
"<br>".$p['respuesta']."";

if (
$p['usuario']=="1" and $p['correcta']=="1") {
    echo 
"Es Correcta<br>";
    }    elseif (
$p['usuario']=="0" and $p['correcta']=="1") {
            echo 
"Es Incorrecta<br>";
            }    elseif (
$p['usuario']=="1" and $p['correcta']=="0") {
                echo 
"Es Incorrecta<br>";
                }    elseif (
$p['usuario']=="0" and $p['correcta']=="0") {
                    echo 
"Es Incorrecta<br>";
                    }    elseif (
$p['usuario']=="2") {
                         echo 
"No respondio<br>";
                        }
    }  
}
desconectar(); 
Se que no es de lo mejor, y tampoco es lo mas optimo, pero estoy estudiando php a medida que en mi trabajo lo necesito. y como estoy medio apretado con los tiempos estoy medio complicado para hacer algo optimizado...

Ahora tengo otra consulta que hacer... espero que me la puedan solucionar...

Esta consulta como veran en la ultima parte me fijo si el usuario ha respondido en forma correcta, incorrecta o si no ha respondido.. aqui tengo un problema, las respuestas correctas tienen el valor "1" las incorrectas "0" y las que no responde "2". Necesito hacer la sumatoria del puntaje, pero mi problema es que como existe n varias respuestas para cada pregunta no puedo hacer una consulta sencilla. ya que se trata de checbox y el usuario podria haber respondido a todas las preguntas y aprobaria el examen, por mas que haya respondido tambien las incorrectas.

Me puden ayudar con este ultimo temita....

PD// podria ser crear una tabla con la cantidad de respuestas correctas que tiene cada pregunta y hacer una consulta a esa tabla y comparar si la cantidad de respuestas correctas es igual a esa tabla y de acuerdo a eso hacer la sumatorio..????

Gracias de antemano..
  #5 (permalink)  
Antiguo 14/04/2008, 07:49
(Desactivado)
 
Fecha de Ingreso: diciembre-2006
Mensajes: 529
Antigüedad: 17 años, 4 meses
Puntos: 11
De acuerdo Re: Consulta SQL complicada... AYUDA

Recuerdo haber respondido algo parecido a esto.
Tienes una forma de resolver todo con una sola consulta sql y sin tanto código anidado.

http://www.forosdelweb.com/f18/relac...tablas-572321/

Saludos
  #6 (permalink)  
Antiguo 14/04/2008, 08:49
(Desactivado)
 
Fecha de Ingreso: enero-2008
Ubicación: Mendoza
Mensajes: 458
Antigüedad: 16 años, 2 meses
Puntos: 2
Re: Consulta SQL complicada... AYUDA

Gracias usermax... estoy viendo el tema de las consultas anidadas... ahora me podrian ayudar con la segunda consulta que postee... con respecto al la sumatoria del puntaje...

Gracias
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 18:03.