簡體   English   中英

幫助查詢

[英]help with a query

我有一個功能,可以通過id獲取所選用戶的評分,它從一種類型的事物獲得評分,而從diff類型的事物獲得評分,然后執行a + 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

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'
    )

另外,當只在結果數組中使用關聯鍵時,使用mysql_fetch_assoc()的速度要比mysql_fetch_array()快得多。

當您僅使用數字鍵時,同樣適用於使用mysql_fetch_row()。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM