oracle递归查询性能优化,请教这个递归查询如何优化

我的一个递归查询如下,递归查询的表也就1000多行,但执行出来却花了240多秒,请教下怎么优化!!!

select distinct mtt.taskitem_id

from security_taskitem mtt,

(

select mrt.task_id

from security_userrole mur,

security_role mrt

where mur.user_id = 2

and mur.role_id = mrt.role_id

) temp

connect by mtt.task_id = prior mtt.taskitem_id

start with mtt.task_id in(temp.task_id)

执行计划

SELECT STATEMENT, GOAL = CHOOSE

SORT UNIQUE

CONNECT BY WITHOUT FILTERING

COUNT

NESTED LOOPS

NESTED LOOPS

TABLE ACCESS FULL                SECURITY_USERROLE

TABLE ACCESS BY INDEX ROWID        SECURITY_ROLE

INDEX UNIQUE SCAN        PK_SECURITY_ROLE

TABLE ACCESS FULL        SECURITY_TASKITEM

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值