动态网站制作指南 [  QQ表情  ]
[ 投票调查 ]
[ 企业邮箱 ]
[ 网站空间 ]
网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
ASP源码 | .Net源码 | PHP源码 | JSP源码 | JAVA源码 | CGI源码 | VB源码 | C++源码 | Delphi源码 | PB源码 | VF源码 | 汇编 | 服务器
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > 数据库 > Oracle教程
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
数据库:数据库教程,数据库技巧,Oracle教程,MySQL教程,Sybase教程,Access教程,DB2教程,数据库安全,数据库文摘
文章搜索服务
邮件订阅
输入你的邮件地址,
你将不会错过任何关于:
[ Oracle教程 ]的信息

本月文章推荐
.如何解决不能一次创建多表的问题.
.[转贴]ORACLE表空间恢复方案.
.Oracle 9i Real Application Clu.
.ORACLE SQL性能优化系列(一).
.PL/SQL基础:阶层查询.
.Oracle 8x中监控sysdba角色.
.Linux 安装经验之安装无盘工作站.
.使用treemaps图形化表示数据库.
.建立与Oracle服务器连接的两种连.
.核心设定档.
.PL/SQL 快速建立DB_LINK.
.ORACLE SQL性能优化系列(五).
.Oracle 和 PHP 使用入门.
.Oracle 中巧用FORMS_DDL.
.Oracle 全球解答的最hot的21个问.
.Oracle 数据库管理脚本命名规范.
.oracle概念和术语.
.转载:Statspack的安装使用说明.
.ORACLE数据库不用索引来查找数据.
.Redhat9下安装Oracle 9.2.

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

发表日期:2008-2-9 |



  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)
上一篇:Oracle 9i 数据库设计指引全集(4) 人气:480
下一篇:Oracle 9i 数据库设计指引全集(1) 人气:509
浏览全部Oracle教程的内容 Dreamweaver插件下载 常用网页广告代码全集
  最新网站源码 最新软件下载
2008-10-13 爬爬思特新闻管理系统 v2.0 Beta1
2008-10-13 Pligg v9.9.5 Beta
2008-10-13 广优邮件发送系统 v2.1
2008-10-13 缤纷互动视频交友 v3.1 RC
2008-10-13 MyShop网络商城 build 081005
2008-10-13 Chyrp 超轻量级开源博客引擎 v2.
2008-10-13 162100静态(论坛/文章)系统 v2.4
2008-10-13 金博人才招聘求职网黄金版 v4.2
2008-10-13 愚人笔记 v4.0
2008-10-11 联系人分组工具 v1.1 中文破解版
2008-10-11 FaceMelter变脸 v2.0 汉化破解版
2008-10-11 PathTracker道路跟踪仪 v1.2 破解
2008-10-11 Rooms手机聊天室 v0.6.7 破解版
2008-10-11 RemoteDesktop远程桌面 v1.0 破解
2008-10-11 ProRemote远程调音台 v1.0.1 破解
2008-10-11 PicShare照片共享 v1.0.0 破解版
2008-10-11 Photogene照片编辑器 v1.5 汉化破
2008-10-11 WriteRoom共享文档 v1.0 破解版
  发表评论
姓 名: 验证码:
内 容:
站长工具:网站收录查询 | Google PR查询 | ALEXA排名查询 | CSS在线编辑器 | 广告代码 | js/vbs加密 | md5加密 | 进制转换 | UTF-8 转换工具 | Html转换js | Html转换asp | Html转换php | Html转换perl
实用工具:汉字翻译拼音 | 拼音字典 | 符号对照表 | 个税计算 | 实时汇率查询换算 | 经典小工具 | 汉字简繁转换 | 普通单位换算 | 公制单位换算 | 生辰老黄历 | 国内电话区号 | 国家代码与域名缩写 | 文字加密解密 | 健康查询 | 万年历 | 汉字横竖排版 | 手机号码查询 | 计算器 | ip搜索
业务联系 | 广告刊登 | 频道合作 | 投稿荐稿 | 联系方式 | 加入收藏 | RSS订阅
Copyright © 2000-2008 www.knowsky.com All rights reserved | 网络实名:动态网站制作指南 | 沪ICP备05001343号
ホームページ制作 不動産検索システム 求人情報
防水工事·改修工事 フットサル大会 探偵
SEO対策 中国語教室 ホームページ作成