`

Oracle随机函数

阅读更多

1.基础认识

关于这些函数及DBMS_RANDOM包的文件都包含在SQLPlus中:
     select text   from all_source
      where name = 'DBMS_RANDOM'
       and type = 'PACKAGE' order by line;

   ◆ TYPE      num_array
   ◆ PROCEDURE terminate
   ◆ PROCEDURE seed
   ◆ PROCEDURE initialize
   ◆ FUNCTION random
   ◆ FUNCTION value RETURN NUMBER;
   ◆ FUNCTION value (low IN NUMBER, high IN NUMBER) RETURN NUMBER;
   ◆ FUNCTION normal RETURN NUMBER;
   ◆ FUNCTION string (opt char, len NUMBER) RETURN VARCHAR2;


2.应用举例

SELECT DBMS_RANDOM.RANDOM FROM DUAL;
 
再进一步的要求,比如,产生一个0-100的随机数,稍微变通一下就可以了:
 
select abs(mod(dbms_random.random,100)) from dual

3.进阶说明

dbms_random又有新函数了可以实现这些功能
FUNCTION value RETURN NUMBER;
FUNCTION value (low IN NUMBER, high IN NUMBER) RETURN NUMBER;
FUNCTION normal RETURN NUMBER;
FUNCTION string (opt char, len NUMBER)   RETURN VARCHAR2; 
 
产生N到M之间的随机数
SELECT   DBMS_RANDOM.VALUE(N,M) FROM DUAL;
 
缺省DBMS_RANDOM.VALUE返回0到1之间的随机数

SQL> select dbms_random.value, dbms_random.value(55,100) from dual;
VALUE            DBMS_RANDOM.VALUE(55,100)
--------------- -----------------------------
0.714469037747011      68.5593418279622
 
NORMAL函数返回服从正态分布的一组数。此正态分布标准偏差为1,期望值为0。这个函数返回的数值中有68%是介于-1与+1之间,95%介于-2与+2之间,99%介于-3与+3之间。
最后,是STRING函数。它返回一个长度达60个字符的随机字符串。

用DBMS_RANDOM生成文本和日期值

数字、文本字符串和日期都是用户会在表格里碰到的三种常见数据类型。虽然你可以用PL/SQL程序包里的DBMS_RANDOM随机生成数字——它确实能够做到这一点——它还能够随机生成文本和日期值。

1.产生随机数字
就让我们先从数字开始。VALUE函数会返回一个大于等于0但是小于1的数,精度是38位。

SELECT DBMS_RANDOM.VALUE FROM DUAL;

对于指定范围内的整数,要加入参数low_value和high_value,并从结果中截取小数(最大值不能被作为可能的值)。所以对于0到99之间的整数,你要使用下面的代码:

SELECT TRUNC(DBMS_RANDOM.VALUE(0, 100)) FROM DUAL;

2.产生随机文本字符串
要随机生成文本字符串,就要使用STRING函数并编写代码指定字符串的类型和所希望的长度:

SELECT DBMS_RANDOM.STRING('A', 20) FROM DUAL;

类型代码在《Oracle Database 10g PL/SQL程序包和类型参考(Oracle Database 10g PL/SQL Packages and Types Reference)》有说明。

下面是一些类型的代码:

‘U’用来生成大写字符

‘L’用来生成小写字符

‘A’用来生成大小写混合的字符

3.产生随机日期
Oracle将日期作为过去某个关键日期(如果你好奇的话,我可以告诉你这个日期是公元前4712年1月1日)的整数偏移量来保存。这就意味着你可以通过寻找与你希望的起始日期相对应的整数,然后向它加入一个随机的整数来随机生成一个指定范围内的日期。

使用TO_CHAR函数和‘J’格式代码,你可以为今天的日期生成一个内部日期数:

SELECT TO_CHAR(SYSDATE, 'J') FROM DUAL;

例如,要生成一个2003年内的任意日期,你可以首先确定2003年1月1日的日期整数;

SELECT TO_CHAR(TO_DATE('01/01/03','mm/dd/yy'),'J')FROM DUAL;

系统给的结果是2452641。所以要生成该年度内的任意日期,我们就要用带有low_value等于2452641和high_value等于2452641+364参数的DBMS_RANDOM.VALUE,再把它转换成日期:

SELECT TO_DATE(TRUNC(DBMS_RANDOM.VALUE(2452641,2452641+364)),'J') FROM DUAL;

 

select to_char(sysdate,'yyyy-MM-dd HH24:mi:ss') from dual;//mi是分钟

分享到:
评论

相关推荐

    Oracle随机函数之dbms_random使用详解

    Oracle的DBMS_RANDOM是一个强大的包,它提供了多种用于生成随机数据的函数,广泛应用于测试、数据分析、模拟等场景。在Oracle数据库中,你可以利用这些函数来创建不可预测的数据,这对于测试应用程序或者填充测试...

    oracle 110个常用函数.zip

    9. 随机函数:DBMS_RANDOM.RANDOM()生成随机数,DBMS_RANDOM.VALUE()生成指定范围内的随机数。 10. 连接查询和嵌套查询中使用的函数,如CONNECT_BY_ROOT()和LEVEL用于层次查询,而子查询中可能用到的任何函数,如...

    Oracle统一社会信用代码自定义效验函数

    标签"Oracle 自定义函数"强调了这个函数是在Oracle环境中实现的,这意味着它必须遵循Oracle的语法和规范,且可以被其他Oracle SQL查询或PL/SQL程序调用。 从文件名"统一代码Oracle函数效验"我们可以推测,压缩包内...

    基于Oracle罚函数的自适应约束差分进化算法.pdf

    【Oracle罚函数】Oracle罚函数是一种在约束优化问题中广泛使用的数学工具,它通过引入一个惩罚项来处理约束条件的违反。在优化过程中,如果一个解违反了约束,Oracle罚函数会增加相应的惩罚,使得违反约束的解在目标...

    oracle函数得到下一个法定工作日期

    本篇文章将深入探讨如何使用Oracle内置函数以及自定义函数来实现这一功能。我们将结合具体的代码示例来理解这一过程。 首先,Oracle提供了一些内置的日期函数,如`SYSDATE`获取当前日期,`ADD_MONTHS`增加月份,`...

    第三章 Oracle常用函数.pdf

    Oracle数据库系统是一个广泛使用的商业关系型数据库管理系统(RDBMS),它提供了多种内建的函数,以便于用户在进行数据查询、数据处理、以及数据转换等操作时能够更加便捷。本文档将详细介绍初学者在学习Oracle...

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

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

    Oracle 汉字拼音简码获取

    本文将详细介绍Oracle数据库中实现这一功能的方法,包括函数的结构、工作原理以及实际应用场景。 #### 函数结构与原理 给定的代码片段展示了如何在Oracle数据库中创建一个名为`ZLSPELLCODE`的函数,用于获取汉字...

    SQL Server和Oracle常用函数对比

    在数据库管理领域,SQL Server 和 ...这些函数在 SQL Server 和 Oracle 中的差异主要体现在语法和命名上,但功能基本一致,使得在两个系统之间进行数据迁移或查询时,开发人员需要了解这些差异以便进行相应的转换。

    Oracle随机启动

    ### Oracle随机启动知识点详解 #### 一、Oracle随机启动概述 在Linux环境下,为了实现Oracle数据库服务能够在系统启动时自动启动,通常会采用特定的方法来配置。本篇将重点介绍如何通过修改`/etc/oratab`文件以及...

    oracle常用函数

    Oracle提供了`DBMS_RANDOM.VALUE(0,1)`生成0到1之间的随机浮点数。 13. **取符号**: `SIGN(-8)`函数返回-1,表示负数;对于正数返回1,对于0返回0。 14. **圆周率**: Oracle中没有内置的PI函数,但可以使用`...

    Oracle插入随机数

    在Oracle数据库管理中,有时我们需要向数据库表中插入大量的随机数据来进行测试、演示或者数据模拟分析等工作。本篇文章将详细介绍如何利用自定义的Oracle函数来实现这一功能。 #### 自定义Oracle函数 为了实现向...

    Oracle里取随机数的几种具体的方法

    除了使用 DBMS_RANDOM 包外,还有其他方法可以生成随机数,例如使用 Oracle 的内置函数、使用 PL/SQL 语言等。这些方法可以根据实际情况选择。 Oracle 提供了多种方法来生成随机数,每种方法都有其优缺点,选择合适...

    Oracle OCP 考试模拟器

    模拟器的特点在于它能够随机出题,这意味着每次练习时的题目顺序和选项都会有所不同,这种设计有助于考生在不同的环境下检验自己的理解和应变能力。用户需要手动添加考题和答案,这既是学习过程的一部分,也使得用户...

    SQLServer和Oracle的常用函数对比.docx

    在SQL Server和Oracle数据库系统中,函数是进行数据操作和计算的重要工具。下面将详细对比这两者中的一些常用函数。 1. **绝对值** - SQL Server: `ABS(-1)` 返回-1的绝对值,即1。 - Oracle: `ABS(-1)` 与SQL ...

    利用ORACLE实现数据的抽样

    本文将深入探讨如何在Oracle数据库环境下实现数据抽样,具体涵盖简单随机抽样、系统抽样、整群抽样以及分层抽样四种常见抽样方法,并详细解析Oracle特有的抽样功能。 ### 一、抽样方法概览 #### 1. 简单随机抽样 ...

    Oracle字符集id,16位id以及name

    ID ID(Hex) Name ID ID(Hex) Name ID ID(Hex) Name 1 0001 US7ASCII 2 0002 WE8DEC 3 0003 WE8HP 4 0004 US8PC437 5 0005 WE8EBCDIC37 6 0006 WE8EBCDIC500 7 0007 WE8EBCDIC1140 8 0008 WE8EBCDIC285 9 0009

Global site tag (gtag.js) - Google Analytics