zzzzz_zyyyyy 2022-03-30 11:17 采纳率: 100%
浏览 49
已结题

Oracle查询出column1一致column2不一致的数据

问题遇到的现象和发生背景

因为工作原因需要查询出column1一致column2不一致的数据,我自己写了下面这段sql可以实现,但是感觉自己把sql写复杂了,请问这段sql还能再简化吗,我用的是oracle

问题相关代码,请勿粘贴截图

select b.column1 from (
select column1 from tableName group by column1 having count()>1
) a left join tableName b on a.column1 = b.column1 group by b.column1,b.column2 having count(
)=1

  • 写回答

3条回答 默认 最新

  • DarkAthena ORACLE应用及数据库设计方案咨询师 2022-03-30 13:50
    关注

    不一致不就是不相等么?没明白你为什么会想着写个这么复杂的sql

    select * from tableName  where column1 <>column2
    

    如果有空值

    select * from tableName  where nvl(column1,'x') <>nvl(column2,'x')
    

    column1一致column2不一致,查询结果只需要对应的column1有哪些值的话

    select column1 from tableName group by column1 having count(distinct column2)>1
    

    如果需要同时展示原表所有字段数据,要么用上面这个数据作为匹配条件,要么用开窗函数来实现只对原表进行一次查询

    select * from (
    select a.*,count(distinct column2) over(partition by column1) ct from tableName  a)
    where ct>1
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 4月8日
  • 已采纳回答 3月31日
  • 创建了问题 3月30日

悬赏问题

  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
  • ¥50 如何openEuler 22.03上安装配置drbd
  • ¥20 ING91680C BLE5.3 芯片怎么实现串口收发数据
  • ¥15 无线连接树莓派,无法执行update,如何解决?(相关搜索:软件下载)
  • ¥15 Windows11, backspace, enter, space键失灵