dpnv33177 2014-09-24 20:44
浏览 53
已采纳

选择不同条目的最新条目

Im having a brain fart as to how I would do this. I need to select only the latest entry in a group of same id entries

I have records in an appointment table.

  lead_id   app_id
     4        42
     3        43
     1        44
     2        45
     2        46 (want this one)
     1        48
     3        49 (this one)
     4        50 (this one)
     1        51 (this one)

The results I require are app_id 46,49,50,51

Only the latest entries in the appointment table, based on duplicate lead_id identifiers.

  • 写回答

3条回答 默认 最新

  • dqyin0101 2014-09-24 20:57
    关注

    I think this is much more optimal and efficient way of doing it (sorting next grouping):

    SELECT * FROM (
        SELECT * FROM appointment
        ORDER BY lead_id, app_id DESC 
    ) AS ord
    GROUP BY lead_id 
    

    this will be useful when you need all other fields too from the table without complicated queries

    Result:

    lead_id     app_id
    1           51
    2           46
    3           49
    4           50
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 使用ue5插件narrative时如何切换关卡也保存叙事任务记录
  • ¥20 软件测试决策法疑问求解答
  • ¥15 win11 23H2删除推荐的项目,支持注册表等
  • ¥15 matlab 用yalmip搭建模型,cplex求解,线性化处理的方法
  • ¥15 qt6.6.3 基于百度云的语音识别 不会改
  • ¥15 关于#目标检测#的问题:大概就是类似后台自动检测某下架商品的库存,在他监测到该商品上架并且可以购买的瞬间点击立即购买下单
  • ¥15 神经网络怎么把隐含层变量融合到损失函数中?
  • ¥15 lingo18勾选global solver求解使用的算法
  • ¥15 全部备份安卓app数据包括密码,可以复制到另一手机上运行
  • ¥20 测距传感器数据手册i2c