`
guming123416
  • 浏览: 18664 次
  • 性别: Icon_minigender_1
  • 来自: 上海
最近访客 更多访客>>
社区版块
存档分类
最新评论

Oracle 随机获取N条数据

阅读更多

      当我们获取数据时,可能会有这样的需求,即每次从表中获取数据时,是随机获取一定的记录,而不是每次都获取一样的数据,这时我们可以采取Oracle内部一些函数,来达到这样的目的.  

select * from (select * from tablename order by sys_guid()) where rownum < N;   
select * from (select * from tablename order by dbms_random.value) where rownum< N;   
select *  from (select * from table_name sample(10)   order by trunc(dbms_random.value(0, 1000)))  where rownum < N;  
 说明: sample(10)含义为检索表中的10%数据,sample值应该在[0.000001,99.999999]之间.  
     其中 sys_guid() 和 dbms_random.value都是内部函数,通过这样的方法,就可以实现我们的需求了.  
   注:  
      在使1)方法时,即使用sys_guid() 这种方法时,有时会获取到相同的记录,即和前一次查询的结果集是一样的,我查找了相关资料,有些说是和操作系统有关,在windows平台下正常,获取到的数据是随机的,而在linux等平台下始终是相同不变的数据集,有些说是因为sys_guid()函数本身的问题,即sys_guid()会在查询上生成一个16字节的全局唯一标识符,这个标识符在绝大部分平台上由一个宿主标识符和进程或进程的线程标识符组成,这就是说,它很可能是随机的,但是并不表示一定是百分之百的这样
 所以,为确保在不同的平台每次读取的数据都是随机的,我们大多采用2)和3)两种方案,其中2)方案更常用.3)方案缩小了查询的范围,在查询大表,且要提取数据不是很不多的情况下,会对查询速度上有一定的提高,  
  
   另:在Oracle中一般获取随机数的方法是:  
select trunc(dbms_random.value(0, 1000)) from dual; (0-1000的整数)  
select dbms_random.value(0, 1000) from dual; (0-1000的浮点数)  
分享到:
评论

相关推荐

    Oracle里抽取随机数的多种方法

    在 Oracle 中抽取随机数是许多应用场景中常见的问题,例如在某个活动中需要随机取出一些符合条件的用户,以颁发获奖通知或其它消息。本文将通过实例讲解如何抽取随机数的多种方法。 首先,我们可以使用 Oracle 自带...

    SQL随机提取N条记录

    在SQL(Structured Query ...以上就是关于“SQL随机抽取N条记录”的详细解释,这些方法可以帮助你从数据库中获取随机样本,无论是进行数据分析还是其他目的。记住,根据你使用的具体SQL方言,可能需要调整上述代码。

    oracle常用问题解答

    **问题**: 如何在Oracle中随机抽取前N条记录? **解答**: 可以使用`RAND`函数配合`RANK`函数来实现。 - **示例**: 抽取前5条记录: ```sql SELECT * FROM ( SELECT t.*, RANK() OVER (ORDER BY DBMS_RANDOM.VALUE...

    富士通内部培训ORACLE资料

    9. **随机抽取记录**:要随机抽取前N条记录,可以结合`ROWNUM`和`ORDER BY DBMS_RANDOM.VALUE`实现。 10. **指定范围抽取记录**:从N行到M行的记录可通过子查询配合`ROWNUM`实现,如 `(SELECT * FROM table WHERE ...

    oracle-18c-新特性

    2. **Top-N 近似聚合**:可以在允许的小误差范围内获取最相关的数据项,如 Top 5 博客文章阅读量或 Top 50 客户的消费情况。 #### 六、机器学习算法新特性 Oracle 18c 在机器学习领域引入了许多新特性: 1. **新的...

    ORACLE9i_优化设计与系统调整

    §1.1.1 Oracle数据字典 23 §1.1.2 表空间与数据文件 24 §1.1.3 Oracle实例(Instance) 24 §1.2 Oracle文件 26 §1.2.1 数据文件 26 §1.2.2 控制文件 26 §1.2.3 重做日志文件 26 §1.2.4 其它支持文件 26 §...

    基于oracle的在线考试系统的设计

    总结,基于Oracle的在线考试系统设计涵盖了数据库基础架构、数据操作逻辑以及性能优化等多个方面。通过精心设计的表结构、视图、触发器、函数和存储过程,能够实现稳定、高效的考试服务,为用户提供流畅的在线考试...

    Oracle 11gR2 for RHEL6 安装手册含备份方案超详细-魏伟新版

    让oracle和oem随机启动 设置Oracle服务和OEM管理工具随系统启动。 ```bash [root@wwrh2 ~]# chkconfig --add oraDB11g_home1 [root@wwrh2 ~]# chkconfig --add oraDB11g_tns1 ``` #### 五、数据库常见备份方案 ...

    Oracle维护常用SQL语句

    #### 三、随机抽取N条记录 在Oracle中,随机抽取数据可以通过`SYS_GUID()`或`DBMS_RANDOM.VALUE`函数实现。以下是两种方法: 1. 使用`SYS_GUID()`函数: ```sql SELECT * FROM ( SELECT * FROM TABLENAME ORDER...

    数据挖掘工具应用前景

    数据挖掘(Data Mining)作为一种新兴技术,其主要任务是从大量的、不完整的、有噪声的、模糊的、随机的数据中,提取出隐藏在其内部的有效信息、模式以及规律。通过运用先进的算法和技术,数据挖掘能够帮助人们从...

    oracle10g加密解密[归类].pdf

    ` 插入一条随机生成的 32 字节密钥。 4. **加密类型和模式**: `ENCRYPTION_TYPE` 定义了加密算法和模式。在示例中,`DBMS_CRYPTO.ENCRYPT_AES256 + DBMS_CRYPTO.CHAIN_CBC + DBMS_CRYPTO.PAD_PKCS5` 表示使用 AES...

    oracle chm帮助文件下载

    27. **获取N大值**:`NTILE()`函数可用于将数据分成N个桶,然后选取每个桶的最大值。 28. **输出到文本**:`UTL_FILE`包提供了文件I/O功能,可以在Oracle中将查询结果输出到文本文件。 29. **存储过程权限**:使用...

    us-18-Boeck-Young-Return-Of-Bleichenbachers-Oracle-Threat.pdf

    它首先以00起始,接着是02表示块类型(用于加密),随后是一段随机数据,一个00,03表示TLS版本号,再次是03,最后是预主密钥(Pre-Master Secret)。例如,03 03表示TLS 1.2版本。随机字节的使用是为了增加破解的...

    专题资料(2021-2022年)SMSE10管理表对象.ppt

    常规表是最常见的数据存储方式,数据按随机顺序存储;索引组织表则是根据索引顺序来组织数据;聚簇表将具有相同键值的数据物理地聚集在一起;而分区表则将大表分成较小、更易管理的部分,每个部分称为分区。 2. ...

    oracle中rownum和row_number()

    4. `ROWNUM` 不能在 `WHERE` 子句中直接使用来获取第n行之后或之前的行,而 `ROW_NUMBER()` 可以通过子查询实现。 在实际应用中,根据具体需求选择使用 `ROWNUM` 或 `ROW_NUMBER()`。如果需要简单的行号分配且不...

    PHP开发实战1200例(第1卷).(清华出版.潘凯华.刘中华).part1

    实例068 SESSION购物车中数据的读取 100 实例069 员工信息的管理 102 实例070 网页版九九乘法表 104 实例071 读取数组购物车中的数据 105 实例072 图像验证码的生成 106 2.6 跳转语句 107 实例073 控制页面中表情图...

    PHP开发实战1200例(第1卷).(清华出版.潘凯华.刘中华).part2

    实例068 SESSION购物车中数据的读取 100 实例069 员工信息的管理 102 实例070 网页版九九乘法表 104 实例071 读取数组购物车中的数据 105 实例072 图像验证码的生成 106 2.6 跳转语句 107 实例073 控制页面中表情图...

    华为大数据HCIE-v2.0版本笔试题库.docx

    7. **正态分布**:若随机变量X服从正态分布N(u,σ²),则线性变换Y=aX+b服从正态分布N(aμ+b, a²σ²)。 8. **数据预处理**:ETL(Extract, Transform, Load)是数据处理流程,用于数据清洗和转换。在数据预处理...

Global site tag (gtag.js) - Google Analytics