sql: 查询重复数据,并查询出,指定条件下,该重复数据出现的次数 15

我用的下面的语句查重,selectid,count(*)-1重复次数fromtabnamegroupbyidhavingcount(*)>1查出来的结果是id重复次数16... 我用的下面的语句查重,
select id,count(*) -1 重复次数
from tabname
group by id
having count(*) > 1
查出来的结果是
id 重复次数
1 6
2 4
3 1
现在我想要查到的结果是:
id 重复次数 name1 name2 name3
1 6 3 2 1
2 4 2 1 1
3 1 1 0 0
即统计出,name值等于name1、2、3的数据中,各个id重复出现的次数

该怎么办
展开
 我来答
frogley
推荐于2018-04-16 · TA获得超过1854个赞
知道小有建树答主
回答量:1008
采纳率:50%
帮助的人:1081万
展开全部
--查询指定条件下的重复次数
--测试数据
with tabname(id,name) as (
select 1,'name1' union all
select 1,'name1' union all
select 1,'name1' union all
select 1,'name2' union all
select 1,'name2' union all
select 1,'name3' union all
select 2,'name1' union all
select 2,'name1' union all
select 2,'name2' union all
select 2,'name3' union all
select 3,'name1')

select id,(name1+name2+name3) as 重复次数,name1,name2,name3 from(
  select id,name from tabname
) as a
pivot(
  count(name) 
  for
  name in (name1,name2,name3)
) as b

结果:

星空下的man
2014-06-20 · 超过32用户采纳过TA的回答
知道答主
回答量:167
采纳率:50%
帮助的人:40.2万
展开全部
select id,count(*) -1, count(name1) as name1, count(name2) as name2, count(name3) as name3 from tabname
group by id
having count(*) > 1
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式