国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > Oracle > 正文

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

2024-08-29 13:29:15
字體:
來源:轉載
供稿:網友
 天寒地凍,呆在家里又讀完了《mastering oracle sql》2nd,發現oracle的功能還是很強悍,光函數就有兩百個,hsql是很難比擬的。接下來的硬骨頭,看來要么冒險用hibernate3.0的sql mapping功能,要么就自己跑jdbc組裝vo了。       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, 見下例
    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)

商業源碼熱門下載www.html.org.cn

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 新干县| 且末县| 曲麻莱县| 珠海市| 鹤山市| 禹州市| 亳州市| 绥江县| 渑池县| 神农架林区| 晋中市| 咸宁市| 门源| 甘肃省| 女性| 康马县| 兴安县| 大荔县| 治多县| 方正县| 民丰县| 安化县| 黄龙县| 鹰潭市| 依安县| 利辛县| 张家界市| 绥江县| 绥阳县| 吴旗县| 象州县| 康马县| 得荣县| 丁青县| 绥江县| 三都| 竹山县| 西乡县| 博客| 顺平县| 肥城市|