oracle中用于生成随机数的包:DBMS_RANDOM,这个包里面包含了很多方法,以下列出几个常用的方法

1.DBMS_RANDOM.RANDOM方法:

  • FUNCTION random RETURN BINARY_INTEGER;

  说明:random返回的是BINARY_INTEGER类型值,产生一个任意大小的随机数(正或负)。

  示例:

SELECT DBMS_RANDOM.RANDOM FROM DUAL;
RANDOM
----------
-478838704 --产生一个任意大小的随机正数
SELECT abs(DBMS_RANDOM.RANDOM/100) FROM DUAL;
ABS(DBMS_RANDOM.RANDOM/100)
---------------------------
698869.43 --产生一个100以内的随机正数(mod取余,可指定其它数字以内的数)
SELECT ABS(MOD(DBMS_RANDOM.RANDOM,100)) FROM DUAL;
ABS(MOD(DBMS_RANDOM.RANDOM,100))
--------------------------------
60

2.DBMS_RANDOM.VALUE用法:有两种用法

  • FUNCTION value RETURN NUMBER;

  说明:这种用法没有参数,会返回一个具有38位精度的数值,范围从0.0到1.0,但不包括1.0。

  示例:

--产生一个0~1之间的随机数
sql>SELECT dbms_random.value FROM dual; VALUE
----------
.625810105 --产生一个100~1000之间的随机数,不带小数(trunc)
sql>SELECT TRUNC(100+900*DBMS_RANDOM.VALUE) FROM dual;
TRUNC(100+900*DBMS_RANDOM.VALUE)
--------------------------------
743
  • FUNCTION value (low IN NUMBER, high IN NUMBER) RETURN NUMBER;

  说明:value带有两个参数,第一个指下限,第二个指上限,将会生成下限到上限之间的数字,但不包含上限。

  示例:

--产生一个10~20之间的随机数
sql>SELECT dbms_random.value(10,20) FROM dual; DBMS_RANDOM.VALUE(10,20)
------------------------
11.1480576

3.DBMS_RANDOM.NORMAL用法:

  • FUNCTION normal RETURN NUMBER;

  说明:获取正态分布的随机数。此正态分布标准偏差为1,期望值为0。这个函数返回的数值中有68%是介于-1与+1之间,95%介于-2与+2之间,99%介于-3与+3之间。

  示例:

sql>BEGIN
  FOR i IN 1 .. 10 LOOP
  dbms_output.put_line(round(dbms_random.normal));
  END LOOP;
END;
  /
0
0
0
0
-1
2
-1
-1
2
0
PL/SQL 过程已成功完成。

4.dbms_random.string用法:

  • FUNCTION string (opt CHAR, len NUMBER) RETURN VARCHAR2;

  说明:某些用户管理程序可能需要为用户创建随机的密码。使用10G下的dbms_random.string 可以实现这样的功能。

  参数:opt :

  ■ 'u', 'U' - returning string in uppercase alpha characters >返回大写字母

  ■ 'l', 'L' - returning string in lowercase alpha characters >返回小写字母

  ■ 'a', 'A' - returning string in mixed case alpha characters >大小写字母混合

  ■ 'x', 'X' - returning string in uppercase alpha-numericcharacters >大写字母和数字混合

  ■ 'p', 'P' - returning string in any printable characters. >任意可显示字符

  Otherwise the returning string is in uppercase alphacharacters. >当选项为其他字母的时候返回的内容仍将是大写字母

  len :表示返回的字符串长度。

  示例:

sql> SELECT DBMS_RANDOM.STRING('u', 10) FROM DUAL
UNION ALL
SELECT DBMS_RANDOM.STRING('U', 10) FROM DUAL
UNION ALL
SELECT DBMS_RANDOM.STRING('l', 10) FROM DUAL
UNION ALL
SELECT DBMS_RANDOM.STRING('L', 10) FROM DUAL
UNION ALL
SELECT DBMS_RANDOM.STRING('a', 10) FROM DUAL
UNION ALL
SELECT DBMS_RANDOM.STRING('A', 10) FROM DUAL
UNION ALL
SELECT DBMS_RANDOM.STRING('x', 10) FROM DUAL
UNION ALL
SELECT DBMS_RANDOM.STRING('X', 10) FROM DUAL
UNION ALL
SELECT DBMS_RANDOM.STRING('P', 10) FROM DUAL
UNION ALL
SELECT DBMS_RANDOM.STRING('P', 10) FROM DUAL; DBMS_RANDOM.STRING('U',10)
------------------------------------------------------------------
MBYRHYLAZA
QSZAEWXBTZ
pidhbftajy
erutcrkoqs
HIjazdaqws
zrjqndNkjh
UMNRRQDEKS
K18GHLWM40
&gp$fx5#Ik
<90<Luu%vT

5.dbms_random.seed用法

  • PROCEDURE seed(val IN BINARY_INTEGER);或PROCEDURE seed(val IN VARCHAR2);

  说明:用于生成一个随机数种子,设置种子的目的是可以重复生成随机数,用于调试。否则每次不同,难以调度。

  --可以设置seed来确定随机数的起始点,对于相同的seed而言,随机数的任意一次变化都将是确定的。
  – 就是说,如果在某一时刻调用了seed,之后第一次产生的随机数是4,第二次是6,第三次是1,
  – 那么当你再次调用相同的seed之后,一次产生的随机数还是4、6、1
  – seed有两种,一种是数 型的,一种是字符型(最大长度2000)的

  示例:

--session1
SELECT USERENV('SESSIONID') FROM DUAL; USERENV('SESSIONID')
--------------------
15140521 SQL> BEGIN
    dbms_random.seed(100);
  END;
  / PL/SQL procedure successfully completed SQL> SELECT DBMS_RANDOM.value
  FROM DUAL
  CONNECT BY LEVEL < 10; VALUE
----------
0.53801770
0.67499536
0.65362270
0.76351985
0.29859834
0.40522032
0.99551636
0.39565580
0.18074760
--SESSION 2
SQL> SELECT USERENV('SESSIONID') FROM DUAL; USERENV('SESSIONID')
--------------------
15140517 SQL> BEGIN
  dbms_random.seed(100);
END;
/ PL/SQL procedure successfully completed SQL> SELECT DBMS_RANDOM.value FROM DUAL
CONNECT BY LEVEL < 10; VALUE
----------
0.53801770
0.67499536
0.65362270
0.76351985
0.29859834
0.40522032
0.99551636
0.39565580
0.18074760

注意:当随机数据做为过滤条件时如下这么写:会找不到数据、多行

 SELECT * FROM test WHERE n = ROUND(dbms_random.value(1,3));--可改成 n = (SELECT ROUND(dbms_random.value(1,3)) FROM dual)

SQL> SELECT n FROM test1 WHERE n = ROUND(dbms_random.value(1,3));
N
----------
1
2
SQL> SELECT n FROM test1 WHERE n = ROUND(dbms_random.value(1,3));
未选定行 SQL> SELECT n FROM test1 WHERE n = ROUND(dbms_random.value(1,3));
N
----------
1

你无法预测或者控制SQL里面调用这个函数的次数。
正确的办法是先将dbms_random.value存入变量,然后在SQL中使用这个变量

DBMS_RANDOM 用法的更多相关文章

  1. oracle系统包——dbms_random用法及order by 小结(转)

    dbms_random是一个可以生成随机数值或者字符串的程序包. 这个包有initialize().seed().terminate().value().normal().random().strin ...

  2. oracle系统包——dbms_random用法

    oracle中随机数的包的源文件目录:{oracle_home}\rdbms\admin\dbmsrand.sql 1.返回0~1间的随机数(包括0和1)sql> select dbms_ran ...

  3. Oracle DBMS_RANDOM

    DBMS_RANDOM.VALUE -- [0,1)的38位精度小数 SELECT DBMS_RANDOM.VALUE FROM DUAL; -- [10,20)的38位精度小数 SELECT DBM ...

  4. Oracle中dbms_random.string 的用法

    转载:https://blog.csdn.net/simonchi/article/details/8657787 DBMS_RANDOM.STRING(var1,var2) 这个函数有两个参数 va ...

  5. [转]Oracle dbms_random函数用法快速生成多条测试数据

    Java 随机生成中文姓名,手机号,邮编,住址:http://blog.csdn.net/xiaokui_wingfly/article/details/45913885 Java 批量随机生成身份证 ...

  6. Oracle dbms_random包的用法

    1.dbms_random.value方法 dbms_random是一个可以生成随机数值或者字符串的程序包.这个包有initialize().seed().terminate().value().no ...

  7. Oracle之DBMS_RANDOM包详解

    DBMS_RANDOM是Oracle提供的一个PL/SQL包,用于生成随机数据和字符.它具有以下函数. 其中,initialize,random,terminate函数在Oracle11g中已不推荐使 ...

  8. Oracle的trunc和dbms_random.value随机取n条数据

    今天在review项目代码的时候看到这样一个问题,有一张号码表,每次需要从这样表中随机取6个空闲的号码,也就是每次取出来的6个号码应该都会有所不同.然后我就看到了这样的SQL select   t.* ...

  9. ORACLE中使用DBMS_RANDOM去产生随机数

    一.生成随机字符串:DBMS_RANDOM.STRING 用法:DBMS_RANDOM.STRING(选项, 返回字符串长度) 选项有如下几种可供选择:1)'u', 'U' - returning s ...

随机推荐

  1. web12 使用map型的request、session、application

    电影网站:www.aikan66.com 项目网站:www.aikan66.com 游戏网站:www.aikan66.com 图片网站:www.aikan66.com 书籍网站:www.aikan66 ...

  2. JAVA学习IO(1)

    面向过程和面向对象的区别:面向过程:把问题分析成一个一个步骤组成的过程面向对象:从一个问题中分析出各个功能对象,并描述各个功能在整个解决问题的步骤的行为.面向对象的3大特征:封装,继承,多态封装:把多 ...

  3. Java面试& HashMap实现原理分析

    1. HashMap的数据结构 数据结构中有数组和链表来实现对数据的存储,但这两者基本上是两个极端.  数组 数组存储区间是连续的,占用内存严重,故空间复杂的很大.但数组的二分查找时间复杂度小,为O( ...

  4. Source Insight中的多行注释

    转自:http://www.cnblogs.com/dongzhiquan/archive/2013/03/04/2943448.html 我们经常要对一整段代码进行注释,很多代码编辑器都提供了这样的 ...

  5. FineReport基本使用

    FineReport官方开发文档链接:http://help.finereport.com 1.FineReport是帆软软件有限公司自主研发的一款企业级web报表软件产品.FineReport报表软 ...

  6. maven编译,控制台中文乱码解决方案

    如下图,在使用maven运行后,在控制台看到中文展示乱码 出现这个的原因是源码使用UTF-8,但是maven编译的时候使用GBK标准,如下图   为了让maven编译的时候使用UTF-8标准,使用在p ...

  7. windows多线程(六) 互斥量Mutex与关键段CriticalSection比较

    一.关键段CS 和 互斥量Mutex 的相同点:都有线程拥有权 关键段和互斥量都有线程拥有权,即可以被一个线程拥有.在 前面讲关键段CS的文章中有说到,关键段结构体的第四个参数保存着拥有该关键段的线程 ...

  8. [转帖]超能课堂 CPU制作过程

    http://www.expreview.com/50814.html 一般来说,我们对IC芯片的了解仅限于它概念,但是对于已经应用到各式各样的数码产品中IC芯片是怎么来的?大家可能只知道制作IC芯片 ...

  9. win7 32位 import cv2 失败 ImportError:DLL load fail:找不到指定模块

    引起问题的可能性太多,这里记录比较一下比较少见的错误原因 缺少dll文件 https://www.dll-files.com/api-ms-win-downlevel-shlwapi-l1-1-0.d ...

  10. P3165 [CQOI2014]排序机械臂

    题目描述 为了把工厂中高低不等的物品按从低到高排好序,工程师发明了一种排序机械臂.它遵循一个简单的排序规则,第一次操作找到高度最低的物品的位置 P1P_1P1​ ,并把左起第一个物品至 P1P_1P1 ...