如何解决为什么“OR”运算符比oracle中的union慢
有谁知道为什么ORACLE中的“OR”运算符比union慢。
Select
O.Order_number,DA. ID,DA.Country,Sum(amount) Amount
from
Order O
left join Delivery_Address DA on
O.ID = DA.order_Id
left join TBL_A on
TBL_A.DA_ID = DA.ID
enter code here
< ... Left joining another 10 tables>
enter code here
Left join Transaction Tr on
TR.Order_id = Order.id
where
DA.Country = 'USA'
OR
Tr.transaction_Date between to_date('20200701','yyyymmdd') and sysdate
前 50 条记录需要 200 秒。
Select
O.Order_number,DA.ID,Sum(amount) Amount
from
Order O
left join Delivery_Address DA on
O.ID = DA.order_Id
left join TBL_A on
TBL_A.DA_ID = DA.ID
enter code here
< ... Left joining another 10 tables>
enter code here
Left join Transaction Tr on
TR.Order_id = Order.id
where
DA.Country = 'USA'
union
Select
O.Order_number,Sum(amount) Amount
from
Order O
left join Delivery_Address DA on
O.ID = DA.order_Id
left join TBL_A on
TBL_A.DA_ID = DA.ID
enter code here
< ... Left joining another 10 tables>
enter code here
Left join Transaction Tr on
TR.Order_id = Order.id
where
Tr.transaction_Date between to_date('20200701','yyyymmdd') and sysdate
对于前 50 条记录,第二个查询需要 13 秒。
Transaction 表中的 transaction_date 已编入索引,但 Country 列未编入索引。
有人知道吗?
解决方法
OR
允许独立评估每个子查询。
您必须查看执行计划才能了解实际情况。但是,在第一个子查询查询中,使用 da.country
的索引可能正在使用索引。在第二个中,tr.transaction_date
。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。