douye9822 2013-11-18 09:21
浏览 31
已采纳

将排序算法应用于数据库查询[关闭]

I want to make another list with "What's Hot" like reddit.

I found this topic where it explains how their sorting algorithm works

First I want to ask, if it is legal to use their algorithm?

And if yes, how would I apply it to PHP database query. Do I need to SELECT all posts first and then sort it?

function hot($ups, $downs, $date) {
    $s = $ups - $downs;
    $order = log(max(abs(s), 1), 10);
    if(s > 0) {
        $sign = 1;
    } elseif(s < 0) {
        $sign = -1;
    } else {
        $sign = 0;
    }
    $date = new DateTime($date);
    $seconds = $date->format('U');
    return round($order + $sign * $seconds / 45000, 7);
}

this is what I get when I convert it to PHP.

  • 写回答

1条回答 默认 最新

  • duan6301 2013-11-18 20:40
    关注

    Assuming your ups and downs columns are called ups and downs, then something like:

    ORDER BY ROUND(
        ( LOG10(
              GREATEST(
                  ABS(`ups` - `downs`), 
                  1
              )
          ) + 
          SIGN(`ups` - `downs`) *
          UNIX_TIMESTAMP(`date_posted`)  / 45000
        ),
        7
    )
    

    It might be a better idea to use this formula to create a calculated column in your select list, and then order by that column

    EDIT

    Example of a calculated column:

    SELECT `ups`,
           `downs`,
           `posted_date`,
           ROUND(
               ( LOG10(
                   GREATEST(
                       ABS(`ups` - `downs`), 
                       1
                   )
                 ) + 
                 SIGN(`ups` - `downs`) *
                 UNIX_TIMESTAMP(`date_posted`)  / 45000
               ),
               7
           ) AS hotness
      FROM `posts`
    

    So hotness is your calculated column

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥50 potsgresql15备份问题
  • ¥15 Mac系统vs code使用phpstudy如何配置debug来调试php
  • ¥15 目前主流的音乐软件,像网易云音乐,QQ音乐他们的前端和后台部分是用的什么技术实现的?求解!
  • ¥60 pb数据库修改与连接
  • ¥15 spss统计中二分类变量和有序变量的相关性分析可以用kendall相关分析吗?
  • ¥15 拟通过pc下指令到安卓系统,如果追求响应速度,尽可能无延迟,是不是用安卓模拟器会优于实体的安卓手机?如果是,可以快多少毫秒?
  • ¥20 神经网络Sequential name=sequential, built=False
  • ¥16 Qphython 用xlrd读取excel报错
  • ¥15 单片机学习顺序问题!!
  • ¥15 ikuai客户端多拨vpn,重启总是有个别重拨不上