举个例子
id num1 num2
1 0 15
2 2 20
3 1 33
2 2 20
1 0 15
2 2 12
3 3 16
相同的id,num1同列的数值完全相同,和num2同列的数值完全相同,就算通过
按照上面的例子,最终输出结果应该是
id num1 num2
1 0 15
1 0 15
因为id2和3的num1与num2不完全相同,所以就不需要了
网上找了下,好像lag能实现?但是我自己不知道怎么搞,还请指教一下这个能怎么实现,不用lag也行,只要能实现这个需求就可以,谢谢各位
试试下面的sql语句吧
SELECT e1.id,e1.num1,e1.num2
FROM 表名 e1
INNER JOIN
(
SELECT id,num1,num2
FROM 表名
GROUP BY id,num1,num2
HAVING count(*)>=2
)e2
ON e1.id=e2.id AND e1.num1=e2.num1 AND e1.num2=e2.num2
proc sql;
create table co_004_7 as
select * from (
select subjid,count(distinct cats(c2,c3,c4,c5,c6,c7,c8,c9)) as num
from co_004_6
group by subjid
) b
where num = 1;
quit;