php - 帮助查询

标签 php mysql sql

我有一个函数,可以通过 id 获取所选用户的评分, 它获取一种类型事物的评级、不同类型事物的评级,然后执行 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'
    )

关于php - 帮助查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4664958/

相关文章:

php - 有没有办法让 Visual Studio Code 识别 PHP 文件中的 HTML 语法

php - 如果特定图像显示 PHP,则显示特定文本

c# - MySQL 连接字符串不起作用

sql - 检查登录的截断/更改权限

php - 如何创建表之间的关系?

Javascript 变量不可见

mysql - MySQL 中何时使用单引号、双引号和反引号

mysql - SELECT 命令计算百分比

mysql - 解释这个使用变量显示数据库列表的 SQL 查询

java - 为什么在这里找不到适合 mysql 消息的驱动程序?