数据库oracle中怎么用distinct取消重复行

例如一个表xskc中有c_id,s_id俩字段,我要取消c_id的重复行,显示c_id和s_id。程序是什么?... 例如一个表xskc中有c_id,s_id俩字段,我要取消c_id的重复行,显示c_id和s_id。程序是什么? 展开
 我来答
big_tree_ivan
推荐于2017-12-15 · 超过18用户采纳过TA的回答
知道答主
回答量:53
采纳率:0%
帮助的人:0
展开全部
首先,对你的需求有点模糊,取消c_id的重复行,然后还显示c_id,s_id。上面两个SQL不知道是否满足你的需求,就比如
select distinct c_id,s_id from xskc ,这条语句消除的是c_id和s_id同时一样的记录,所以单就c_id,还是会有重复的情况。
SQL> desc dup
Name Null? Type
----------------------------------------- -------- ----------------------------
ID NUMBER
NAME VARCHAR2(10)

SQL> select * from dup;

ID NAME
---------- ----------
1 AAA
2 AAA
1 BBB
3 BBB
SQL> select distinct id,name from dup;

ID NAME
---------- ----------
1 AAA
1 BBB
2 AAA
3 BBB

SQL> select distinct id from dup;

ID
----------
1
2
3

所以不管怎么样,如果你要显示c_id和s_id的话,c_id基本都可能重复,除非你还有其他的条件限制
jing7206477
2013-01-27
知道答主
回答量:7
采纳率:0%
帮助的人:5.3万
展开全部
想针对个别字段取消重复行的话,可以对该字段使用group by语句,例如:
select c_id, min(s_id)
from xskc
group by c_id

Distinct 是确保整行数据不重复的,就像其他朋友已经说明的。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
csuxp2008
2009-07-22 · TA获得超过6485个赞
知道大有可为答主
回答量:4704
采纳率:50%
帮助的人:2461万
展开全部
distinct只能用于消除重复的行,而不能消除重复的字段
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友5fa1849
2015-10-20 · TA获得超过102个赞
知道小有建树答主
回答量:128
采纳率:100%
帮助的人:64万
展开全部
直接在重复的列名前加distinct就行了
比如 select distinct sno from student
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
华夏日长兴
2009-07-22 · TA获得超过9592个赞
知道大有可为答主
回答量:6305
采纳率:85%
帮助的人:3718万
展开全部
select distinct c_id,s_id from xskc
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(4)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式