广

MYSQL

  • MYSQL
  • MSSQL
  • Redis
  • MongoDB
  • oracle数据库
  • 数据管理

    使用mysql的disctinct group by查询不重复记录

    2018-05-08 11:29:28 次阅读 稿源:互联网
    零七网广告
    全网推广平台,软文发布
    有个需求,一直没有解决,在google上找了半天,给出的方案没有一个能用了,最后鬼使神差搞定了。
       是这样的,假设一个表:

    id   f_id    value   
    1     2         a   
    2     2         b   
    3     5         c   
    4     9         c   
    5     9         a   
    6     6         d  

    id   f_id    value
    1     2         a
    2     2         b
    3     5         c
    4     9         c
    5     9         a
    6     6         d
       id是主键,f_id是外键,我需要获得不重复的外键f_id的数据,如果用group by 或者distinct很容易搞定


    select f_id from table group by f_id
    select distinct f_id from table
       但如果再想在结果中得到id值的话,不管怎么都会乱。比如我想在结果中用id进行排序,诸如”select distinct f_id, id from table order by id desc”完全白费。在google上看了大量的例子,发现需要在select中对id做手脚,让mysql知道除了f_id外,对id应该进行如何的操作。诸如Max, Min, Avg,Sun..都是可以的,于是变成以下的代码就搞定了……

    select f_id, max(id) as id from table group by f_id order by id desc
       搞定,网上有个文章很接近答案,但是他没有”as id”,导致在我的mysql中执行结果有误,呵呵。

    零七网部分新闻及文章转载自互联网,供读者交流和学习,若有涉及作者版权等问题请及时与我们联系,以便更正、删除或按规定办理。感谢所有提供资讯的网站,欢迎各类媒体与零七网进行文章共享合作。

    零七网广告
    零七网广告
    零七网广告
    零七网广告