您的当前位置:首页正文

oracle优化or替换为in、exists、unionall的几种写法,测试没

2020-11-09 来源:汇智旅游网

oracle 优化or 替换为in、exists、union的几种写法,测试没有问题! 根据实际情况用选择相应的语句吧!如果有索引,or全表扫描,in 和not in 也要慎用,否则会导致全表扫描, select * from T_Pro_Product where bar_code = nnnmmm or name = nnnmmm or no =

oracle 优化or 替换为in、exists、union的几种写法,测试没有问题!

根据实际情况用选择相应的语句吧!如果有索引,or全表扫描,in 和not in 也要慎用,否则会导致全表扫描,

 select *
   from T_Pro_Product
  where bar_code = 'nnnmmm'
     or name = 'nnnmmm'
     or no = 'nnnmmm';

select *
 from T_Pro_Product
 where 'nnnmmm' in (bar_code, name, no)
 
 --忧化
 select *
 from T_Pro_Product t1
 where exists
 (select 1
 from T_Pro_Product tt1
 where t1.bar_code = 'nnnmmm'
 union all
 select 1
 from T_Pro_Product tt2
 where t1.no = 'nnnmmm'
 union all
 select 1 from T_Pro_Product tt3 where t1.name like 'n%')
 
 --忧化
 select *
 from T_Pro_Product t1
 where t1.id in (select id
 from T_Pro_Product tt1
 where t1.bar_code = 'nnnmmm'
 union all
 select id
 from T_Pro_Product tt2
 where t1.no = 'nnnmmm'
 union all
 select id
 from T_Pro_Product tt3
 where t1.name = 'nnnmmm')
显示全文