baidu_32457989 2015-12-28 07:15 采纳率: 0%
浏览 4500
已采纳

关于mysql查询差值的方法

当前我有表test,字段id,click,share
我的需求是
算出同一id,click数最大的click和share,减去click第二大的click和share

  • 写回答

4条回答 默认 最新

  • 谁用了我的英文名 2015-12-28 15:58
    关注

    分析:
    从题主描述的字段值猜测,这是一个类似于“热帖排序”的问题,id并不是我们通常认为的主键id,而是关联到帖子的外键。click值在排序上高于share值,因此先看click再看share,通过两者的一个加权值取得排序结果。
    对于题主所描述的直接需求,个人意见是先limit0,2选取到这两条数据,然后到程序里面慢慢处理,省脑子。
    如果一定要用sql语句完成,那大概是:
    select t1.click1-t2.click2, t1.share1-t2.share2 from (
    select click as click1,share as share1 from test order by click limit0,1
    ) t1 join (
    select click as click2,share as share2 from test order by click limit1,1
    ) t2

    分析“加权值排序”怎么实现。设value = function(click, share);
    那么可以
    select test.* from(
    select function(click,share) as value from test
    ) ids left join test on ids.id = test.id ordy by ids.value

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

悬赏问题

  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 保护模式-系统加载-段寄存器