假设有一个表格,如下:
每组序号内,都有几个互为正负数的数据,如果我想去除这些互为相反数的记录,保留无相反数的记录,该怎样去写SQL能达到目的呢?碰到这个问题实在无思路了,希望各位能指点下迷津,感谢
假设有一个表格,如下:
每组序号内,都有几个互为正负数的数据,如果我想去除这些互为相反数的记录,保留无相反数的记录,该怎样去写SQL能达到目的呢?碰到这个问题实在无思路了,希望各位能指点下迷津,感谢
1、这个用左连接或 not exists等等都可以实现的
-- 左连接
select a.* from t a left join t b on a.数字 = -b.数字 where b.序号 is null;
-- not exists
select * from t a where not exists( select 1 from t b where a.数字 = -b.数字 );
额……楼下考虑了 0 的特殊情况,就看题主是否需要排除 0,如果不需要排除 0 可以参数楼下的写法(当然 “t.序号 = ta.序号 and”部分需要删除掉,不然得不到想要的结果),也可以这样写:
-- 左连接
select a.* from t a left join t b on a.数字 = -b.数字 where a.数字 = 0 or b.序号 is NULL;
-- not exists
select * from t a where a.数字 = 0 or not exists( select 1 from t b where a.数字 = -b.数字 );
另外我还在MySQL 5.7、Oracle、PostGresQL以及SQLServer中试了一下,a.数字 = -b.数字 这个全都是能使用的,都能得到正确的结果