`
江南白衣
  • 浏览: 555017 次
  • 来自: 广州
社区版块
存档分类
最新评论

Oracle SQL依然无可替代--《Mastering Oracle SQL》

阅读更多

    天寒地冻,呆在家里又读完了《Mastering Oracle SQL》2nd,发现Oracle的功能还是很强悍,光函数就有两百个,那些面向对象的查询语言很难模拟,特别是SQL2003里针对OLAP的windows function等。
    幸好Hibernate3.0也支持SQL了。 

       1.报表合计专用的Rollup函数
         销售报表
  广州     1月      2000元
  广州     2月      2500元
  广州                 4500元
  深圳     1月      1000元
  深圳     2月      2000元
  深圳                 3000元
  所有地区         7500元

以往的查询SQL:
Select  area,month,sum(money) from SaleOrder group by area,month
然后广州,深圳的合计和所有地区合计都需要在程序里自行累计

1.其实可以使用如下SQL:
   Select area,month,sum(total_sale) from SaleOrder group by rollup(area,month)
就能产生和报表一模一样的纪录
 
2.如果year不想累加,可以写成
   Select year,month,area,sum(total_sale) from SaleOrder group by year, rollup(month,area)
   另外Oracle 9i还支持如下语法:
   Select year,month,area,sum(total_sale) from SaleOrder group by rollup((year,month),area)
 
3.如果使用Cube(area,month)而不是RollUp(area,month),除了获得每个地区的合计之外,还将获得每个月份的合计,在报表最后显示。
 
4.Grouping让合计列更好读
  RollUp在显示广州合计时,月份列为NULL,但更好的做法应该是显示为"所有月份"
  Grouping就是用来判断当前Column是否是一个合计列,1为yes,然后用Decode把它转为"所有月份"
  Select  Decode(Grouping(area),1,'所有地区',area) area,
          Decode(Grouping(month),1,'所有月份',month),
          sum(money)
  From SaleOrder 
  Group by RollUp(area,month);
 
2.对多级层次查询的start with.....connect by
   比如人员组织,产品类别,Oracle提供了很经典的方法
 SELECT LEVEL, name, emp_id,manager_emp_id
FROM employee
START WITH manager_emp_id is null
CONNECT BY PRIOR emp_id = manager_emp_id;
上面的语句demo了全部的应用,start with指明从哪里开始遍历树,如果从根开始,那么它的manager应该是Null,如果从某个职员开始,可以写成emp_id='11'
CONNECT BY 就是指明父子关系,注意PRIOR位置
另外还有一个LEVEL列,显示节点的层次
 
3.更多报表/分析决策功能
3.1 分析功能的基本结构
     分析功能() over( partion子句,order by子句,窗口子句)
     概念上很难讲清楚,还是用例子说话比较好.       
 
3.2 Row_Number 和 Rank, DENSE_Rank
    用于选出Top 3 sales这样的报表
    当两个业务员可能有相同业绩时,就要使用Rank和Dense_Rank
    比如
              金额    RowNum  Rank  Dense_Rank
    张三 4000元    1             1        1
    李四 3000元    2             2        2
    钱五 2000元    3             3        3
    孙六 2000元    4             3        3
    丁七 1000元    5             5        4
    这时,应该把并列第三的钱五和孙六都选进去,所以用Ranking功能比RowNumber保险.至于Desnse还是Ranking就看具体情况了。
    SELECT salesperson_id, SUM(tot_sales) sp_sales,
    RANK( ) OVER (ORDER BY SUM(tot_sales) DESC) sales_rank
    FROM orders
    GROUP BY salesperson_id
3.3 NTILE 把纪录平分成甲乙丙丁四等
        比如我想取得前25%的纪录,或者把25%的纪录当作同一个level平等对待,把另25%当作另一个Level平等对待
    SELECT cust_nbr, SUM(tot_sales) cust_sales,
    NTILE(4) OVER (ORDER BY SUM(tot_sales) DESC) sales_quartile
    FROM orders
    GROUP BY cust_nbr
    ORDER BY 3,2 DESC;
NTITLE(4)把纪录以 SUM(tot_sales)排序分成4份.
 
3.4 辅助分析列和Windows Function
     报表除了基本事实数据外,总希望旁边多些全年总销量,到目前为止的累计销量,前后三个月的平均销量这样的列来参考.
    这种前后三个月的平均和到目前为止的累计销量就叫windows function,是SQL2003的针对OLAP的新函数, 见下例
    SELECT month, SUM(tot_sales) monthly_sales,
           SUM(SUM(tot_sales)) OVER (ORDER BY month
           ROWS BETWEEN UNBOUNDED PRECEDING AND CURRENT ROW) max_preceeding
    FROM orders
    GROUP BY month
    ORDER BY month;



    SELECT month, SUM(tot_sales) monthly_sales,
           AVG(SUM(tot_sales)) OVER (ORDER BY month
           ROWS BETWEEN 1 PRECEDING AND 1 FOLLOWING) rolling_avg  
    FROM orders
    GROUP BY month
    ORDER BY month;
    Windows Function的关键就是Windows子句的几个取值
    1 PRECEDING 之前的一条记录
    1 FOLLOWING 之后的一条记录
    UNBOUNDED PRECEDING 之前的所有记录
    CURRENT ROW 当前纪录
 
4.SubQuery总结
  SubQuery天天用了,理论上总结一下.SubQuery 分三种
  1.Noncorrelated 子查询   最普通的样式.
  2.Correlated Subqueries  把父查询的列拉到子查询里面去,头一回cyt教我的时候理解了半天.
  3.Inline View                           也被当成最普通的样式用了.
 
  然后Noncorrelated 子查询又有三种情况
  1.返回一行一列    where price < (select max(price) from goods )
  2.返回多行一列    where price>= ALL (select price from goods where type=2)
                          or where NOT price< ANY(select price from goods where type=2)
                              最常用的IN其实就是=ANY()
  3.返回多行多列    一次返回多列当然就节省了查询时间
          UPDATE monthly_orders 
          SET (tot_orders, max_order_amt) =
             (SELECT COUNT(*), MAX(sale_price)
          FROM cust_order)

         
DELETE FROM line_item
          WHERE (order_nbr, part_nbr) IN
           (SELECT order_nbr, part_nbr FROM cust_order c)


分享到:
评论
1 楼 perzer 2011-05-31  
好东西。赞!

相关推荐

    《Mastering oracle SQL》

    经典的ORACLE SQL教程

    mastering oracle sql

    《精通Oracle SQL》是一本深度解析Oracle数据库查询语言的专业书籍,旨在帮助读者全面掌握和熟练运用SQL在Oracle环境中的各种技巧。这本书不仅涵盖了基础的SQL语法,还深入探讨了高级特性和最佳实践,以提高数据库...

    Mastering oracle SQL

    《Mastering Oracle SQL》是一本深入探讨Oracle SQL编程的专业书籍,深受广大数据库管理员和开发人员喜爱。本书旨在帮助读者全面理解和掌握Oracle SQL的核心概念、语法以及优化技巧,从而提升在数据库管理和开发中的...

    Mastering_Oracle_SQL(含源码)

    《Mastering Oracle SQL》是一本深受数据库管理员和开发人员欢迎的专业书籍,主要涵盖了Oracle SQL的高级用法和技术。这本书分为第一版和第二版,提供英文版本,并以CHM( Compiled HTML Help )格式呈现,方便读者...

    Mastering.Oracle.SQL英文第二版及所用到的示例数据表创建脚本

    《Mastering Oracle SQL》是Oracle SQL领域的权威著作,其第二版更是深受数据库管理员、开发人员和数据分析师的青睐。本书全面覆盖了Oracle SQL的各种高级特性,包括查询优化、子查询、联接操作、集合操作、窗口函数...

    Mastering Oracle SQL and SQL Plus

    《Mastering Oracle SQL and SQL Plus》这本书为读者提供了全面而深入的学习资源,涵盖了Oracle SQL的基础知识、高级特性以及SQL Plus的使用技巧。通过本书的学习,不仅可以掌握Oracle SQL的基本操作,还能深入了解...

    Oracle SQL*Plus Pocket Reference, 2nd Edition

    对于想要深入了解SQL*Plus的读者,作者推荐阅读他的另一本著作《Oracle SQL*Plus:The Definitive Guide》(O'Reilly出版社)以及由Sanjay Mishra和Alan Beaulieu合著的《Mastering Oracle SQL》(同样由O'Reilly出版...

    Mastering SQL Server Profiler---一本专业sql教程

    ### Mastering SQL Server Profiler——一本专业SQL教程 #### 一、引言 《Mastering SQL Server Profiler》是一本由Brad McGehee撰写的专为SQL Server用户设计的技术书籍,首次出版于2009年。该书深入浅出地讲解了...

    mastering-spark-sql.pdf

    《mastering-spark-sql.pdf》是Jacek Laskowski编写的关于Spark SQL的深入学习指南,涵盖了从基础知识到高级特性的各个方面。本文将根据文档内容,详细梳理其中涉及的知识点。 首先,文档的开篇介绍了Spark SQL的...

    Mastering.Oracle.SQL.2nd.Edition

    掌握PL/SQL编程,比较基础的一本书

    Mastering_Oracle_SQL学习笔记

    在深入探讨《Mastering Oracle SQL学习笔记》的内容之前,我们先理解一下这门课程的核心目标:帮助初学者更好地掌握SQL语言中的关键概念和操作,尤其是针对Oracle数据库的特性。这包括了SQL语句的构建、数据筛选、...

    mastering-spark-sql

    《Mastering Spark SQL》这本书是Spark SQL领域的权威指南,它深入介绍了如何利用Apache Spark处理大规模数据的SQL查询和分析。Spark SQL是Apache Spark的核心组件之一,它将传统的SQL查询与大数据处理相结合,使得...

    精通ORACLE SQL

    "MASTERING THE ORACLE SQL"这一标题揭示了本书的核心目标,即帮助读者全面、深入地掌握Oracle SQL的精髓,从而成为Oracle数据库管理的专家。 在Oracle SQL的世界里,了解基本的SELECT语句只是入门,真正精通则需要...

    Mastering Oracle PL SQL Practical Solutions

    《掌握Oracle PL/SQL:实用解决方案》一书由Connor McDonald、Chaim Katz、Christopher Beck、Joel R. Kallman和David C. Knox共同撰写,是Oracle PL/SQL领域的权威指南。本书深入探讨了Oracle PL/SQL编程语言的高级...

    Mastering Oracle GoldenGate.pdf

    Oracle GoldenGate是一款在IT行业中被广泛认可的实时数据复制工具,它支持多种数据库类型,包括但不限于Oracle数据库、MySQL、SQL Server、DB2等。这款工具的特性让它在处理数据同步和复制任务时,能够提供近乎实时...

    Mastering-Python-for-Finance.pdf.pdf

    《Mastering Python for Finance》是一本专注于利用Python语言在金融领域实现先进数学和统计应用的书籍。通过这本书,读者可以理解、设计并实施金融领域内使用的各种尖端技术和方法。本书的作者是James Ma Weiming,...

Global site tag (gtag.js) - Google Analytics