m0_57748717 2022-05-27 01:26 采纳率: 76.3%
浏览 53
已结题

oracle一组数据内提出互为相反数的记录

假设有一个表格,如下:

img

每组序号内,都有几个互为正负数的数据,如果我想去除这些互为相反数的记录,保留无相反数的记录,该怎样去写SQL能达到目的呢?碰到这个问题实在无思路了,希望各位能指点下迷津,感谢

  • 写回答

2条回答 默认 最新

  • leaf_cq 2022-05-27 09:19
    关注

    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.数字 这个全都是能使用的,都能得到正确的结果

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 6月4日
  • 已采纳回答 5月27日
  • 创建了问题 5月27日

悬赏问题

  • ¥100 Jenkins自动化部署—悬赏100元
  • ¥15 关于#python#的问题:求帮写python代码
  • ¥20 MATLAB画图图形出现上下震荡的线条
  • ¥15 关于#windows#的问题:怎么用WIN 11系统的电脑 克隆WIN NT3.51-4.0系统的硬盘
  • ¥15 perl MISA分析p3_in脚本出错
  • ¥15 k8s部署jupyterlab,jupyterlab保存不了文件
  • ¥15 ubuntu虚拟机打包apk错误
  • ¥199 rust编程架构设计的方案 有偿
  • ¥15 回答4f系统的像差计算
  • ¥15 java如何提取出pdf里的文字?