繁体   English   中英

比较同一表中的相同列

[英]Comparing same columns in the same table

如果我在表1中有这样的数据

column1 column2 date
111     00      2016-10-11
111     00      2016-10-11
111     20      2016-10-12
111     20      2016-10-12
222     00      2016-10-11
222     20      2016-10-12
333     20      2016-10-11
333     20      2016-10-12

我想构建一个仅选择333作为重复项的查询,因为column1 = column1(333 = 333),column2 = column2(20 = 20)和date <> date(2016-10-11 <> 2016-10-12感谢您

似乎自我加入会奏效...

SELECT T1.*, T2.*
FROM Table1 T1
INNER JOIN table2 T2
 on T1.Column1 = T2.Column1
and T2.column2 = T2.Column2
and T1.Date <> T2.Date

或存在(更快但仅访问T1数据)

SELECT T1.*
FROM Table1 T1
WHERE Exists (Select 1 
              from table1 T2 
              where T1.Column1 = T2.Column1
                and T2.column2 = T2.Column2
                and T1.Date <> T2.Date)
select column1 from table1 t
join table1 jt
  on t.column1 = jt.column1
  and t.column2 = jt.column2
  and jt.date <> jt.date

使用自我加入

 select t1.column1
 from my_table t1
 inner join my_table t2
 on t1.column1 = t2.column2
 and t1.ccolumn2 = t2.column2
 and t1.date <> t2.date

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM