Oracle之DBMS_RANDOM包详解
参考自:https://www.cnblogs.com/ivictor/p/4476031.html
https://www.cnblogs.com/shengs/p/4592747.html

DBMS_RANDOM是Oracle提供的一个PL/SQL包,用于生成随机数据和字符。它具有以下函数:

INITIALIZE
NORMAL
RANDOM
SEED
STRING
TERMINATE
VALUE

其中,initialize,random,terminate函数在Oracle11g中已不推荐使用,主要用于向后兼容。下面对各个函数进行举例说明
1、INITIALIZE
用一个种子值来初始化DBMS_RANDOM包。
默认情况下,DBMS_RANDOM包是根据用户、时间、会话来进行初始化,这样,即便是同一个语句,每次生成的数值都会不一样。
这样会产生一个问题,在测试环境下,如果我想每次生成的随机序列都是一样的,该怎么办?
INITIALIZE函数就很好的解决了这一问题,通过设置相同的种子值,则每次生成的随机序列都将是一样的。
语法:

DBMS_RANDOM.INITIALIZE (
val IN BINARY_INTEGER);

举例:

SQL> BEGIN
2 dbms_random.initialize(100);
3 FOR i IN 1 .. 10 LOOP
4 dbms_output.put_line(dbms_random.random);
5 END LOOP;
6 END;
7 /
163284779
751599369
659804475
1131809137
-865013504
-407075626
2128226600
-448154892
-1371178596
472933400 PL/SQL procedure successfully completed.

即便是在不同的会话中,不同的用户下,随机生成的10个值都是一样的。
2、NORMAL
NORMAL函数返回服从正态分布的一组数。此正态分布标准偏差为1,期望值为0。这个函数返回的数值中有68%是介于-1与+1之间,95%介于-2与+2之间,99%介于-3与+3之间。
语法:

DBMS_RANDOM.NORMAL
RETURN NUMBER;

举例:

SQL> select dbms_random.normal from dual;

NORMAL
----------
.321082788

3、RANDOM
RANDOM返回值的范围为: [-2^31, 2^31),返回的是整数。
语法:

DBMS_RANDOM.RANDOM
RETURN binary_integer;

举例:

SQL> select dbms_random.random from dual;

RANDOM
----------
-1.363E+09

4、SEED
功能和INITIALIZE函数类似,实际上,INITIALIZE函数被淘汰,推荐的替代函数即是SEED函数。与INITIALIZE函数不同的是SEED函数同时支持数值和字符作为种子值,而INITIALIZE函数只支持数值。
语法:

DBMS_RANDOM.SEED (
val IN BINARY_INTEGER);
DBMS_RANDOM.SEED (
val IN VARCHAR2);

举例:

BEGIN
dbms_random.seed('hello');
FOR i IN 1 .. 10 LOOP
dbms_output.put_line(round(dbms_random.value * 100));
END LOOP;
END;
输出如下:
58
71
33
4
39
53
93
37
20
5

其中,VARCHAR2的最大范围为2000.
5、STRING
随机生成字符串
语法:

DBMS_RANDOM.STRING
opt IN CHAR,
len IN NUMBER)
RETURN VARCHAR2;

关于opt和len的说明,解释如下:
取值                             含义
'u'或'U'            返回一个由大写字母组成的字符串
'l'或'L'              返回一个由小写字母组成的字符串
'a'或'A'            返回一个由大写字母和小写字母组成的字符串
'x'或'X'            返回一个由大写字母和数字组成的字符串
'p'或'P'            返回一个由任意的可打印字符组成的字符串
可见,opt指的是字符串的格式,len指的是字符串的长度。

举例:

SQL> select dbms_random.string('u',10) value from dual;

VALUE
--------------------
MCPEZLEQOO SQL> select dbms_random.string('l',10) value from dual; VALUE
--------------------
laufaqufln SQL> select dbms_random.string('a',10) value from dual; VALUE
--------------------
vjEetXlItt SQL> select dbms_random.string('x',10) value from dual; VALUE
--------------------
LAMDGZE22E SQL> select dbms_random.string('p',10) value from dual; VALUE
--------------------
4LF =Q'(fP 

6、TERMINATE
在使用完DBMS_RANDOM包后,用该函数进行终止。该函数在11gR1中即不推荐使用了。
语法:

DBMS_RANDOM.TERMINATE;

举例:

SQL> exec DBMS_RANDOM.TERMINATE;
PL/SQL procedure successfully completed.

7、VALUE
语法:

DBMS_RANDOM.VALUE
RETURN NUMBER;

DBMS_RANDOM.VALUE(
low IN NUMBER,
high IN NUMBER)
RETURN NUMBER;

对于第一种用法,返回的值的范围为大于或等于0,小于1,带有38位精度的小数。
对于第二种用法,可指定最小值和最大值,返回值的范围为大于或等于low,小于high。
举例:

SQL> select dbms_random.value from dual;
VALUE
----------
.291782963 SQL> select dbms_random.value(10,20) from dual; DBMS_RANDOM.VALUE(10,20)
------------------------
12.4079412

Oracle中dbms_random包详解的更多相关文章

  1. Oracle之DBMS_RANDOM包详解

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

  2. oracle中imp命令详解 .

    转自http://www.cnblogs.com/songdavid/articles/2435439.html oracle中imp命令详解 Oracle的导入实用程序(Import utility ...

  3. Oracle中动态SQL详解(EXECUTE IMMEDIATE)

    Oracle中动态SQL详解(EXECUTE IMMEDIATE) 2017年05月02日 18:35:48 悠悠倾我心 阅读数:744 标签: oracle动态sqloracle 更多 个人分类:  ...

  4. ORACLE之UTL_FILE包详解

    1 Utl_File包简介Oracle的UTL_FILE包用来实现对磁盘文件的I/O操作.(1)Oracle10g之前的版本需要指定utl_file包可以操作的目录.      方法:        ...

  5. Oracle中的索引详解

    Oracle中的索引概述 索引与表一样,也属于段(segment)的一种.里面存放了用户的数据,跟表一样需要占用磁盘空间.索引是一种允许直接访问数据表中某一数据行的树型结构,为了提高查询效率而引入,是 ...

  6. oracle中动态SQL详解

    部分内容参考网上资料 1.静态SQLSQL与动态SQL Oracle编译PL/SQL程序块分为两个种:其一为前期联编(early binding),即SQL语句在程序编译期间就已经确定,大多数的编译情 ...

  7. (转)Oracle中动态SQL详解

    本文转载自:http://www.cnblogs.com/gaolonglong/archive/2011/05/31/2064790.html 1.静态SQLSQL与动态SQL Oracle编译PL ...

  8. oracle中的用户详解 【转】

      oracle中的用户很多,也很令初学者费解.oracle中的帐户分为两类:一类是必需的帐户,一类是存储各种应用的帐户 用户名 密码 描述 ANONYMOUS ANONYMOUS 访问http的匿名 ...

  9. [转载]Oracle中动态SQL详解

    1.静态SQLSQL与动态SQL Oracle编译PL/SQL程序块分为两个种:其一为前期联编(early binding),即SQL语句在程序编译期间就已经确定,大多数的编译情况属于这种类型:另外一 ...

随机推荐

  1. 国产新芯片连不上J-Link?芯海CS32L010系列芯片JLink配置方法

    疫情以来芯片供货紧张,特别是ST的MCU一芯难求.所以很多产品不得不切换成国产.不过也是经过使用后才发现,很多国产芯片的性能还是挺好的.由于芯片比较新,官方J-Link还没有支持,所以调试和烧录有些不 ...

  2. DeWeb --- Hello,World!

    1.新建一个DLL,命名为hello.dpr 2.新增一个Form.(File->New->VCL Form - Delphi),建议不要更改单元名称和Form名称,即分别为unit1.p ...

  3. Oracle的主要组件和基本概念

    oracle 简介 oracle(甲骨文)公司 1977年,三人合伙创办(Software Development Laboratories,SDL) 1979年,更名为Relational Soft ...

  4. NCF 中如何将Function升级到FunctionRender

    简介 历史的车轮在不断的向前推进,NCF也在不断的迭代更新,只为成为更好的NCF 如果你之前没有用过NCF可以跳过这个文档,直接去下载最新的NCF源码进行实践. NCF仓库地址:https://git ...

  5. 输入指令npx webpack-dev-server报错:Error: Cannot find module ‘webpack-cli/bin/config-yargs‘的解决方法

    输入指令npx webpack-dev-server报错:Error: Cannot find module 'webpack-cli/bin/config-yargs'的解决方法 输入指令:npx ...

  6. 常用的package.json以及React相关

    常用的package.json以及React相关 前言 package.json 的简单介绍 简单版的 package.json 必备属性(name & version) name 字段 ve ...

  7. PTA 哈利·波特的考试 (25分)

    PTA 哈利·波特的考试 (25分) 哈利·波特要考试了,他需要你的帮助.这门课学的是用魔咒将一种动物变成另一种动物的本事.例如将猫变成老鼠的魔咒是haha,将老鼠变成鱼的魔咒是hehe等等.反方向变 ...

  8. celery ValueError: invalid literal for int() with base 10: '26379;sentinel'

    celery使用redis sentinel作为broker的时候,因为redis sentinel配置字符串格式解析报错 ValueError: invalid literal for int() ...

  9. virtualenv笔记

    virtualenv venv --python=python2.7 mkvirtualenv venv --python=python linux中使用virtualenvwrapper 安装 pi ...

  10. Python基础(使用模块)

    #!/usr/bin/env python3 # -*- coding: utf-8 -*- ' a test module ' __author__ = 'Michael Liao' import ...