在经历了007式的工作模式下,对sql的group by,join,union all等基本函数运用的炉火纯青之后,以为自己的sql屌爆了.
直到碰到一个笔试题:查询重复值?
我只会查是否有重复值啊 老天
我不会这个函数啊,然后在度娘妹子的帮助找到了一些东西,决定总结为笔记(转变一下思路就可以啊,老铁)
我才意识到如果把sql大牛比作一个成年人的话,我的水平也就是一个刚学会叫爸爸妈妈的小孩,还是熊的(QAQ)
1.创建表并插入数据(自己电脑用的mysql,sql语句都差不多)
2.查询重复值(前面嘟嘟一大堆没用的(QTQ))
1)查询结果只显示重复的字段
根据存在重复值的字段分组,求每组的总数,总数大于1的就是有重复值的.查询时加上val字段,就可以显示重复值
如果重读字段大于1的时候 只要在select后面加上a.字段,group by 后面也要加上
2)查询结果显示重复数据的所有字段
把test作为同样的两张表 a和b 然后同时查两个表的内容当a表的id不等于b表的id并且a表的值等于b表的值
如果重读字段大于1的时候 只要在where条件后加上a.字段=b.字段
不过开窗函数可以做到 还没仔细研究