你咋不敢跟旅长干一架呢 2015-09-10 02:58 采纳率: 100%
浏览 4652
已采纳

oracle中或者or和左连接left join 怎么一起使用????

语句
select a.owner_id,count(b1.ship_id) cnt,nvl(sum(b1.dwt),0) dwt
from so_shipowner_info a left join order_info_secondhand_formal b1
on b1.ship_business_date>to_char(sysdate,'yyyy') and (b1.buyer_id=a.owner_id or b1.sellers_id=a.owner_id)
group by a.owner_id
表b1中有卖家sellers_id,买家buyer_id ,表a中有用户owner_id,
逻辑是:输出用户id,b1数量 cnt,b1吨数 dwt,当b1交易时间大于今年年初而且买家id=用户id或者卖家id=用户id,
以a表为基表,进行左连接,但是这个语句执行很慢,想改为(+)和where 条件的,or和(+)不能一起使用.哪位大神有办法????

  • 写回答

1条回答 默认 最新

  • oxcow 2015-09-10 03:19
    关注

    oracle的+其实就是 left/right join on语句。没有区别。

    因为有or语句,所以索引在一定程度上就起不到作用了,走的基本都是全表。 建议可以结合实际业务做优化:

    1、把or部分拆开,用两条查询语句代替,然后做union, 这样话加上索引的话应该改会比当前语句要快
    2、如果一次取出的数据不是很多,可以考虑在内存中进行数据整理。也就是简化SQL,查询出来数据在内容在做过滤。

    如果以上你都不喜欢,还是希望优化你的SQL,那还是执行下查询计划,看下慢在那里了,根据实际情况该加索引加索引,该优化SQL优化SQL,只查询计划展示的结果让你满意为止!

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥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键失灵