Jerry95270628 2016-01-13 12:43 采纳率: 0%
浏览 1467

oracle sql查询语句优化

select moni.p_code,moni.department,moni.monitorserialno,moni.adminname,moni.buildingname from t_monitorroom moni where moni.p_code in
(select roleauth.monitorroomid from t_monitorroom_role_authority roleauth left join
t_monitorroom_user_role userrole on userrole.roleid=roleauth.roleid where userrole.userid='admin')
其中t_monitorroom这个表中有一万多条记录,t_monitorroom_role_authority这个表中是存的角色拥有的t_monitorroom中的权限。
查询需要9秒多钟,求高手支招优化。

  • 写回答

4条回答 默认 最新

  • 全栈极简 博客专家认证 2016-01-13 12:52
    关注

    1、用with as语句
    2、用exists代替in

    评论

报告相同问题?

悬赏问题

  • ¥35 平滑拟合曲线该如何生成
  • ¥100 c语言,请帮蒟蒻写一个题的范例作参考
  • ¥15 名为“Product”的列已属于此 DataTable
  • ¥15 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 自己瞎改改,结果现在又运行不了了
  • ¥15 链式存储应该如何解决
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站