Oracle坑不间断更新

[b][size=large]jdbc date 不走索引[/size][/b]
jdbc中
select * from tba t where t.createtime >?

实际上不走索引(如果createtime是date类型的话),传说会转换为timestamp,对于此类需要改成,
select * from tba t  where t.createtime>to_date(?,'yyyy-mm-dd')


[b][size=large]or 不走索引[/size][/b]
select * from tba t where t.a in (select xxx from xxx) or t.a=b

实际上不走索引
对于此类需要改成,

select * from tba t1 where t.a in (select xxx from xxx)
union
select * from tba t2 where t.2a = 2



[b][size=large]小集合和大集合关联尽量走nestedloop[/size][/b]
接上,使用union以后和另外一张表的ROWID关联,出现这种情况
cost 1 cardinality 150000

接下去的表关联直接采用了HASH JOIN;
如果前面说的不用union关联的话,ROWID关联的结果
cost 1 cardinality 1

因此小表A和大表B,关联字段有索引,那么强制走NESTED LOOP,设置
/*+ordered use_nl(b)*/



[b][size=large]ORACLE 中 为什么使用ROWID快[/size][/b]
在8i以前rowid由file#+block#+row#组成,占用6个bytes的空间,10 bit 的 file# ,22 bit 的 block# ,16 bit 的 row#。
其中oracle 的dba(data block address)是32 bits的,包括10 bit 的 file# 和 22 bit 的block#
详情 http://www.itpub.net/thread-653576-1-1.html
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值