ITPub博客

首页 > 数据库 > Oracle > 课程实践(一)

课程实践(一)

原创 Oracle 作者:luisedalian 时间:2014-01-18 07:11:17 0 删除 编辑
避免常见错误

注意:

打开SQL*Plus时间显示

每次执行之前都要执行@flush清空内存

所有脚本均存在于$HOME/solutions/Common_Mistakes目录中

案例一

将相关子查询方式改为内联视图方式


点击(此处)折叠或打开

  1. --采用相关子查询的方式(bad)
  2. SELECT COUNT(*)
  3. FROM products p
  4. WHERE prod_list_price < 1.15 * (SELECT AVG(unit_cost) FROM costs c WHERE c.prod_id = p.prod_id);

  5.   COUNT(*)
  6. ----------
  7.         46

  8. Elapsed: 00:00:00.33

  9. --采用非相关子查询的方式(good)
  10. SELECT COUNT(*)
  11. FROM products p, (SELECT prod_id, AVG(unit_cost) ac FROM costs GROUP BY prod_id) c
  12. WHERE p.prod_id = c.prod_id AND p.prod_list_price < 1.15 * c.ac;
  13.   COUNT(*)
  14. ----------
  15.         46

  16. Elapsed: 00:00:00.16

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/17013648/viewspace-1072398/,如需转载,请注明出处,否则将追究法律责任。

下一篇: 课程实践(一)续1
请登录后发表评论 登录
全部评论

注册时间:2012-02-06

  • 博文量
    1986
  • 访问量
    5649674