帮助查询

时间:2011-01-12 02:56:50

标签: php mysql sql

我有一个功能,我按ID获得所选用户的评分, 它从一种类型的东西获得评级,一种不同类型的东西的评级然后做一个+ b

我知道它不是很优化,但我专注于完成所有工作......

我这样做

    function votos_usuario($id){

            $previa = "SELECT id FROM preguntas WHERE id_usuario = '$id'";
            $r_previo = mysql_query($previa);
            $ids_p = '0, ';
            while($items_previos = mysql_fetch_array($r_previo)){
                $ids_p .= $items_previos['id'].", ";
                //echo "ids pregunta usuario: ".$items_previos['id']."<br>";
            }
            $ids = substr($ids_p,0,-2);
            //echo $ids;

            $consulta = "SELECT valor FROM votos_pregunta WHERE id_pregunta IN ( $ids )";
            //echo $consulta;

           $resultado = mysql_query($consulta);
           $votos_preguntas = 0;
           while($voto = mysql_fetch_array($resultado)){
             $votos_preguntas = $votos_preguntas + $voto['valor'];
           }
//$votos_preguntas= 0;
//$votos_preguntas = mysql_query("SELECT SUM(valor) FROM votos_pregunta WHERE id_pregunta IN (SELECT id FROM preguntas WHERE id_usuario = '$id')");


           $previa_r = "SELECT id FROM recetas WHERE id_usuario = '$id'";
            $r_previo_r = mysql_query($previa_r);
            $ids_r = '0, ';
            while($items_previos_r = mysql_fetch_array($r_previo_r)){
                $ids_r .= $items_previos_r['id'].", ";
                //echo "ids pregunta usuario: ".$items_previos['id']."<br>";
            }
            $ids = substr($ids_r,0,-2);
            $consulta_b = "SELECT valor FROM votos_receta WHERE id_receta IN ( $ids )";
            //echo $consulta;

           $resultado_b = mysql_query($consulta_b);
           $votos_recetas = 0;
           while($voto_r = mysql_fetch_array($resultado_b)){
             $votos_recetas = $votos_recetas + $voto_r['valor'];
           }





            $total = $votos_preguntas + $votos_recetas;
            return $total;

        }

现在问题,

我怎样才能让所有用户通过评级desc命令?我只是看不到它:S

2 个答案:

答案 0 :(得分:1)

SELECT uid, SUM(Votes)
FROM (
    SELECT p.id_usuario uid, SUM(vp.valor) votes
    FROM preguntas p JOIN votos_pregunta vp ON p.id = vp.id_pregunta 
    GROUP BY p.id_usuario
    UNION ALL
    SELECT r.id_usuario uid, SUM(vr.valor) votes
    FROM recetas r JOIN votos_receta vr ON r.id = vr.id_receta 
    GROUP BY r.id_usuario
) rs
GROUP BY uid
ORDER BY SUM(Votes) DESC

而不是你的php循环和所有子查询,你可以使用这个单一的查询来得到你想要的:

SELECT (
    SELECT SUM(vp.valor) 
    FROM preguntas p JOIN votos_pregunta vp ON p.id = vp.id_pregunta 
    WHERE p.id_usuario = '$id')
    + (
    SELECT SUM(vr.valor)
    FROM recetas r JOIN votos_receta vr ON r.id = vr.id_receta 
    WHERE r.id_usuario = '$id'
    )

答案 1 :(得分:0)

另外,当你只使用结果数组中的关联键时,使用mysql_fetch_assoc()要比mysql_fetch_array()快得多。

同样适用于使用mysql_fetch_row(),而只是使用数字键。