a我考网

 找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 140|回复: 0

[考试辅导] Oracle认证辅导:随机抽取记录的方法

[复制链接]
发表于 2012-8-4 14:06:19 | 显示全部楼层 |阅读模式
最近在做系统时用到了随机抽取记录的问题;   上网上查找了很多相关资料,发现了不同的方法及其差异。都是基于ORACLE的方法哦
* c% H/ J  n8 f8 F" k  首先第一个是随机抽取6个
! @2 ]. o1 e% m5 x5 ?1 n5 r  select * from  (select * from tablename order by order by dbms_random.value) where  rownum<7" Q+ E; I3 t) q0 U, j5 O
  这个方法的原理我认为应该是把表中的数据全部查询出来按照随机数进行排列后在从查询出来的数据中查询中6条记录,这个方法我在使用的过程中发现,如果记录一多的话查询的速度有一点点的慢,测试时是7000条,如果几万几十万的话可能就更慢了;7 A2 ]1 I! `* x4 w+ m% W/ Q
  第二个是利用oracle的sample()或sample block方法
4 \2 ]( b! s2 q( O- I+ d7 F1 o6 h3 [  select * from tablename sample ( 50 ) where rownum<6
. ]0 c  r+ J( P! L- T7 ]" J7 [$ K  这个稍稍介绍一下sample
) R3 K  Z! T0 z  @: A  Oracle访问数据的基本方法有:
* `* S3 T$ q2 ~" _( r/ S  1.全表扫描2.采样表扫描
& [: X2 i' v, I% b8 u  全表扫描(Full table Scan)) j. @! B0 a! A4 {3 g* I
  全表扫描返回表中所有的记录。, _# q& i1 W4 C3 d6 h/ y
  执行全表扫描,Oracle读表中的所有记录,考查每一行是否满足WHERE条件。Oracle顺序的读分配给该表的每一个数据块,这样全表扫描能够受益于多块读.每个数据块Oracle只读一次.
9 {( Y$ U4 N1 ~( \+ Q9 V  采样表扫描(sample table scan)4 ^2 L! H; j4 d$ ?4 W/ Q% o/ ]4 b
  采样表扫描返回表中随机采样数据。
& K) A) G& I- r$ U  这种访问方式需要在FROM语句中包含SAMPLE选项或者SAMPLE BLOCK选项.. C, R0 W) J9 `6 c
  SAMPLE选项:
. t  f% C2 ^0 J" ~. B  当按行采样来执行一个采样表扫描时,Oracle从表中读取特定百分比的记录,并判断是否满足WHERE子句以返回结果。
$ M4 X; a* [" L7 ^. t  SAMPLE BLOCK选项:
! f# x$ k7 E0 ~# }0 O8 u  使用此选项时,Oracle读取特定百分比的BLOCK,考查结果集是否满足WHERE条件以返回满足条件的纪录.
5 q4 |* F2 D! `! ]' g  Sample_Percent:% d/ x' h, T, N9 n9 g& d
  Sample_Percent是一个数字,定义结果集中包含记录占总记录数量的百分比。. X# B' A% w. Q; L# `5 I# a
  Sample值应该在[0.000001,99.999999]之间。
) Y$ J  P* ~% h' o$ F! h- s6 R  L  主要注意以下几点:
9 X  g; h8 `- q5 K5 M  [  1.sample只对单表生效,不能用于表连接和远程表2.sample会使SQL自动使用CBO! u# b( b( \4 H; Z4 ?% q5 c) K
  看法  k6 Q* m) J* O3 m+ g1 e6 w
  我在测试sample 的时候发现如果我的表中数据有20条,按照它的sample值我写这样的sql: select * from tablename sample(50)   应该结果集中的数据占总数据的50%才对,但是多次执行之后的结果却是多少数据都有,小于50%、大于50%的都有,这跟 Sample_Percent是一个数字,定义结果集中包含记录占总记录数量的百分比 的说明不符,而且用sample block时有时候还能查询出空结果集(select * from tablename sample block(50)) ,不知道是不是我对这个理解不够还是。。。,反正感觉很疑惑;
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Archiver|手机版|小黑屋|Woexam.Com ( 湘ICP备18023104号 )

GMT+8, 2024-9-28 08:16 , Processed in 0.256016 second(s), 21 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表