首页 / ORACLE / Oracle中去重复+排序
Oracle中去重复+排序
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了Oracle中去重复+排序,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1683字,纯文字阅读大概需要3分钟。
内容图文
![Oracle中去重复+排序](/upload/InfoBanner/zyjiaocheng/548/73e685d89f4a4be89003e28d8996986f.jpg)
今天朋友问了一个特别纠结的问题: 在数据库的一张表里面对根据表中的某一字段进行去重复并对剩下的数据根据另外一个字段排序,
今天朋友问了一个特别纠结的问题:
在数据库的一张表里面对根据表中的某一字段进行去重复并对剩下的数据根据另外一个字段排序,
创建表如下:
create table TEST_DISTINCT(
ID integer not null,
NAME varchar(20) not null
);
insert into TEST_DISTINCT values(0,'aa');
insert into TEST_DISTINCT values(1,'bb');
insert into TEST_DISTINCT values(2,'cc');
insert into TEST_DISTINCT values(3,'dd');
insert into TEST_DISTINCT values(4,'ee');
insert into TEST_DISTINCT values(5,'aa');
insert into TEST_DISTINCT values(6,'cc');
一看到去重复就想到了 DISTINCT 关键字:
select distinct name from test_distinct;
可惜却无法和字段id关联,于是度娘看见最火的一种写法:
select *, count(distinct name) from table group by name;
select *,count(distinct ename) from emp group by name;
可惜运行直接报错,于是改成了:
select job,ename,count(distinct ename) from emp group by job,ename;
报错是没了,但是还是没效果,后来研究了个把小时还是无法解决,,不知道是不是因为版本原因,总之感觉度娘还是不靠谱!
后来还是找到了解决方法:
两行数据要去掉一个,是应该去掉第一行还是第二行这种情况像电脑这种啥东西肯定不会选择的,于是得用户自己选择
我的方法是:
select max(id) as mt,name from (select * from test_distinct where id > 2) group by name order by mt asc;
如果还有其他字段:
select * from emp where emp.mgr in (
select mm from (
select max(mgr) as mm,ename from (select * from emp where empno > 7521) group by ename order by mm asc
)
nn);
当解决后才发现是如此简单,看见去重走向了distinct的误区了,
另外发这种文章得有品,不能随便发点错的误人子弟啊!
内容总结
以上是互联网集市为您收集整理的Oracle中去重复+排序全部内容,希望文章能够帮你解决Oracle中去重复+排序所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。