• SQL选择不重复记录


    由于设计需要,需要查询不重复的记录值,同类问题,想必大家都遇到过,于是乎马上GOOGLE一下,发现此类问题还挺多,解决方案也不少,仔细看看。
    例如有如下表结构和值
    table
    fid   name  sex
        a      男
        b      男
        c      女
        d      女
        a      男
        b      男
    方案一:distinct
    select distinct name from table
    得到结果:
    name
    a
    b
    c
    d
    实现效果,那如果要同时打开其它记录呢?再试试
    select distinct name,id from table
    测试没什么效果,查下得知,这样实际是要name和id字段都重复才被筛选。继续查找可得如下方法:
    方案二:group by
    select *, count(distinct name) from table group by name

    Oracle下测试失败,据说MYSQL下通过,不管,继续思考....
    翻翻书,试试
    select min(fid),name,sex from table group by name
    成功,现实如下结果:
    fid   name  sex
        a      男
        b      男
        c      女
        d      女
    继续思考,如果要打开所有记录,不指定字段用(*),貌似这方法就不行了!
    select  * from table where fid in(Select min(fid) FROM table group by name)
    测试成功
    fid   name  sex
        a      男
        b      男
        c      女
        d      女
    方案三:
    本来已经完了,突然想起前几天在网上查了查询数据中所有某字段不重复的记录
    select   *   from   table   where   name in(select   name   from   table   group   by   name     having   count(name)=2)
    得到如下结果:
    fid   name  sex
        a      男
        b      男
        a      男
        b      男
    以此类推:
    select   *   from   table   where   name in(select   name   from   table   group   by   name     having   count(name)=1)
    按道理说没问题,大家试试~~
    再多的字段都全部现实。哎,原来如此简单!回顾网上方法distinct,Inner   Join等等,麻烦,而且有很大局限性.
    总结如下:
    select distinct name from table打开不重复记录的单个字段
    select  * from table where fid in(Select min(fid) FROM table group by name)打开不重复记录的所有字段值
    select   *   from   table   where   name in(select   name   from   table   group   by   name     having   count(name)=1)打开不重复任意次数的所有记录

    转自:http://blog.sina.com.cn/s/blog_4581d9820100bg9x.html

  • 相关阅读:
    使用gitlab, jenkins搭建CI(持续集成)系统(1) -- 准备环境
    后台开发技术(2)--接入层设计
    后台开发技术(1)--概述
    【Go】学习笔记兼吐槽(1)
    【PyCharm】书签的使用
    【pygame】Python 不到 300 行代码实现俄罗斯方块
    【杂谈】详解医保报销
    【Python 库】requests 详解超时和重试
    【Python 库】读取 .doc、.docx 两种 Word 文件简述及“Word 未能引发事件”错误
    【Python】鲜为人知的功能特性(下)
  • 原文地址:https://www.cnblogs.com/stalwart/p/1905266.html
Copyright © 2020-2023  润新知