it167.com  设为主页
 收藏本站
 
  资讯:业界动态 | 软件动态 | 人物专栏 | 安全资讯 | 网络生活 | 电子商务 | 小游戏 | 视频 | 美女图片 | 音乐
  网络编程 | 网站运营 | 网页制作 | 图形图象 | 操作系统 | 媒体动画 | 软件教学 | 网络应用 | 邮件系统 | 网络安全 | 认证考试
asp | .net | php | jsp | Sql | java | Dreamweaver | FrontPages | Javascript | css | Coreldraw | photoshop | Flash | Coreldraw
当前位置: > 主页>认证考试>ORACLE认证>Oracle认证:巧取指定记录与外关联查询
最新新闻

·机会与整合 边缘化互联
·TOM-Skype新增三大本地
·雅虎抢闸邮箱竞赛 网易
·新浪抢攻北京奥运
·洞悉网络口碑的掘金机会
·拆解网络病毒黑金交易
·木马下载器近期出现新变
·《互联网周刊》第17期文
·Web2.0是否催生自吹自擂
·三张宝宝裸照招来MSN封
热门新闻
·Oracle 课程描述
·Oracle9i OCM认证实践课
·Oracle认证的专家之见(
·Oracle认证一览(上)
·Oracle 认证的专家之见(
·想知道OCP证书在加拿大
·Oracle认证一览(下)
·Oracle认证常识
·Oracle认证:何时使用绑
·Oracle三层认证计划
推荐新闻
 
 

Oracle认证:巧取指定记录与外关联查询 

作者:   来源:it167   点击:   日期:2007-01-27

  1 取得表中第6到第10条记录的值

  1.1 第一种方法,使用minus语句

  假设ddl语句如下:

  CREATE TABLE T(ID VARCHAR2(4) PRIMARY KEY, VALUE INT)

  那么第一种方法就是取出前5条,再取出前10条,然后采用集合运算的方法把前10条减去前5条就OK了,SQL语句如下

以下是引用片段:
  SELECT * FROM T WHERE ROWNUM <= 10
  MINUS
  SELECT * FROM T WHERE ROWNUM <= 5;


  1.2 另外一种方法,采用子查询

  子查询的这种方法相对比较复杂一点,不过性能要比刚才的集合相减要好一些。这种方法首先在子查询中得到前10条数据,顺路也取得前10条数据的rownum,然后再一次查询的时候取得刚才查询的rownum大于5的那些数据。SQL语句如下

以下是引用片段:
  SELECT ID, VALUE FROM
  (SELECT ID, VALUE, ROWNUM R FROM T WHERE R <= 10)
  WHERE
  R > 5;


  通过上面的语句,就得到了6到第10条数据了。

  2 利用外连接替代not in语句

  in语句还有not in语句的效率是非常的差的,因为数据库在遇到这两种语句的时候是要把数据进行一条一条的比对,如果in或者not in两侧的数据量在上万条的时候,进行比对的次数就是上亿次,很可能一个简单的sql语句就要执行半个小时以上。这种效率客户是肯定不能够接受的。那我们可以考虑两种方法进行替代,第一种就是采用exist语句和not exist语句,这种大家应该比较熟悉了。另外一种就是巧用外关联语句,这种方法可能大家不是很熟悉,我来稍微说一下。假设数据表的建表DDL语句为

  CREATE TABLE T1(ID VARCHAR2(4) PRIMARY KEY, VALUE INT)

  而in或者not in的表的建表DDL语句为

  CREATE TABLE T2(VALUE INT)

  Oracle中外关联采用的是(+)符号表示外关联,也就是说标识了(+)符号的部分在找不到对应的值的时候为NULL。下面是替代in语句的时候的SQL语句

以下是引用片段:
  SELECT T1.ID, T1.VALUE
  FROM T1, T2
  WHERE T1.VALUE = T2.VALUE(+)
  AND T2.VALUE IS NOT NULL;


  而类似的。替代not in语句的时候的SQL语句则为

以下是引用片段:
  SELECT T1.ID, T1.VALUE
  FROM T1, T2
  WHERE T1.VALUE = T2.VALUE(+)
  AND T2.VALUE IS NULL;


  大家可以试验一下,在数据量多的时候,采用外关联比用in或者not in的执行效率要高很多很多。



文章评论】 【收藏本文】 【推荐好友】 【打印本文】 【论坛讨论

   相关文章:
·Oracle9i OCM认证实践课考试的一些说明 ·Oracle认证的专家之见(下)
·Oracle 课程描述 ·Oracle认证一览(上)
·Oracle 认证的专家之见(上) ·想知道OCP证书在加拿大值多少钱吗?

   文章评论:(0条)
  
 请留名: 匿名评论   点击查看所有评论 网管论坛
 

  责任编辑:it167  声明:刊登此文章是为了传递更多信息,文章内容仅供参考,转载请注明出处。