Oracle 随机数

利用oracle的dbms_random包结合rownum来实现,示例如下,随机取499户:
select * from
( select * from busi.t_ar_userinfo order by dbms_random.value)
where rownum < 500;

有关dbms_random的参考文献,链接为:http://www.psoug.org/reference/dbms_random.html

Deprecated. Use the methods in the DBMS_CRYPTO built-in package,这个包已经不建议使用了

附,dbms_random几个参数的介绍:
function value return number,返回一个[0,1)之间的随机数,精度为38位(Gets a random number, greater than or equal to 0 and less than 1, with decimal 38 digits)
function value(low IN NUMVBER,high IN NUMBER) return number,返回一个[low,high)之间的随机数
function normal return number,return random numbers in a standard normal distribution,返回服从正态分布的一组数,标准偏差为1,期望值为0,返回值中68%介于+1 和 -1 之间,95%介于 +2 和 -2 之间,99%介于+3 和 -3之间。
function random return BINARY_INTEGER, (Generate Random Numeric Values),
function string(opt char,length Number) return varchar2(the maximum is 60),返回一个指定长度的字符串( Create Random Strings),opt seed values:
'a','A'&n

问:我工作中的问题:主管让我为了某个活动要随机取出一些符合条件的EMAIL或者手机号码用户,来颁发获奖通知或其它消息,我们公司用的Oracle 9i 请问这个如何实现?  
答:可以用oracle里生成随机数的PL/SQL, 目录文件名在:/ORACLE_HOME/rdbms/admin/dbmsrand.sql。
  用之前先要在sys用户下编译:
  SQL>@/ORACLE_HOME/rdbms/admin/dbmsrand.sql
  它实际是在sys用户下生成一个dbms_random程序包,同时生成公有同义词,并授权给所有数据库用户有执行的权限。
  使用dbms_random程序包, 取出随机数据的方法:
  1. 先创建一个唯一增长的序列号tmp_id
  create sequence tmp_id increment by 1 start with 1 maxvalue 9999999 nocycle nocache;
  2. 然后创建一个临时表tmp_1,把符合本次活动条件的记录全部取出来。
  create table tmp_1 as select tmp_id.nextval as id,email,mobileno from 表名 where 条件;
  找到最大的id号:
  select max(id) from tmp_1;
  假设为5000
  3. 设定一个生成随机数的种子
  execute dbms_random.seed(12345678);
  或者
  execute dbms_random.seed(TO_CHAR(SYSDATE,'MM-DD-YYYY HH24:MI:SS'));
  4. 调用随机数生成函数dbms_random.value生成临时表tmp_2
  假设随机取200个
  create table tmp_2 as select trunc(dbms_random.value(1,5000)) as id from tmp_1 where rownum<201;
  [ 说明:dbms_random.value(1,5000)是取1到5000间的随机数,会有小数,
  trunc函数对随机数字取整,才能和临时表的整数ID字段相对应。
  注意:如果tmp_1记录比较多(10万条以上),也可以找一个约大于两百行的表(假如是tmp_3)来生成tmp_2
  create table tmp_2 as select trunc(dbms_random.value(1,5000)) as id from tmp_3 where rownum<201; ]
  5. tmp_1和tmp_2相关联取得符合条件的200用户
  select t1.mobileno,t1.email from tmp_1 t1,tmp_2 t2 where t1.id=t2.id;
  [ 注意:如果tmp_1记录比较多(10万条以上),需要在id字段上建索引。]
  也可以输出到文本文件:
  set pagesize 300;
  spool /tmp/200.txt;
  select t1.mobileno,t1.email from tmp_1 t1,tmp_2 t2 where t1.id=t2.id order by t1.mobileno;
  spool off;
  6. 用完后,删除临时表tmp_1、tmp_2和序列号tmp_id。

(0)

相关推荐

  • ORACLE随机数DBMS_RANDOM包

    简单得说,通过dbms_random包调用随机数的方法大致有4种: 1.dbms_random.normal 这个函数不带参数,能返回normal distribution的一个number类型,所以基本上随机数会在-1到1之间.     简单测试了一下,产生100000次最大能到5左右: Sql代码 declare i number:=; j number:=; begin for k in .. loop i:= dbms_random.normal; if i > j then j:=i;

  • Python random模块(获取随机数)常用方法和使用例子

    random.randomrandom.random()用于生成一个0到1的随机符点数: 0 <= n < 1.0 random.uniformrandom.uniform(a, b),用于生成一个指定范围内的随机符点数,两个参数其中一个是上限,一个是下限.如果a > b,则生成的随机数n: a <= n <= b.如果 a <b, 则 b <= n <= a 复制代码 代码如下: print random.uniform(10, 20)print rand

  • javascript Math.random()随机数函数

    random函数语法 Math.random(); random函数参数 无参数 random函数返回值 返回0和1之间的伪随机数,可能为0,但总是小于1,[0,1) random函数示例 document.write(Math.random()); 返回随机数 document.write(Math.random()*(20-10)+10); 返回10-20的随机数 document.write(Math.random()*(n-m)+m); 返回指定范围的随机数(m-n之间)的公式

  • c# Random快速连续产生相同随机数的解决方案

    代码如下: 复制代码 代码如下: namespace RandomTest { class Program { static void Main(string[] args) { for (int i = 0; i < 100; i++) { Random d = new Random(); Console.WriteLine(d.Next(100)); } } } } 理论上而言,这个程序会产生100个不同的0-100的整数,而实际情况却是除了第一个数字不同外,剩余99个数字会产生随机的99个

  • Oracle随机函数之dbms_random使用详解

    dbms_random是oracle提供的一个随机函数包,以下介绍一些dbms_random的常用示例: dbms_random.value用法: 生成一个大于等于0,小于等于1的38位小数 复制代码 代码如下: -- FUNCTION value RETURN NUMBER; select dbms_random.value from dual; SQL> select dbms_random.value from dual; VALUE ---------- 0.61011338 复制代码

  • js生成随机数之random函数随机示例

    JavaScript Math.random()内置函数 random函数返回值 返回0和1之间的伪随机数,可能为0,但总是小于1,[0,1) random函数示例 //返回随机数 document.write(Math.random()); //返回10-20的随机数 document.write(Math.random()*(20-10)+10); //返回指定范围的随机数(m-n之间)的公式 document.write(Math.random()*(n-m)+m); 基于时间,亦可以产生

  • Oracle 随机数

    利用oracle的dbms_random包结合rownum来实现,示例如下,随机取499户: select * from ( select * from busi.t_ar_userinfo order by dbms_random.value) where rownum < 500: 有关dbms_random的参考文献,链接为:http://www.psoug.org/reference/dbms_random.html Deprecated. Use the methods in the

  • 全新感受Oracle 9i

    正在看的ORACLE教程是:全新感受Oracle 9i. Oracle 背景资料 在介绍 Oracle9i 之前我们先介绍一些关于 Oracle 公司的资料,让各位朋友更多了解 Oracle. 1977 年,拉里·艾里森和Bob Miner.Ed Oates一起创建一家软件开发实验室(Software Development Laboratories).开发当时新型的数据库技术--关系型数据库系统,并将第一个产品命名为"Oracle",意为"智慧之源".1978年软

  • oracle统计时间段内每一天的数据(推荐)

    下面给大家介绍oracle统计时间段内每一天的数据,具体sql语句如下所示: 1. 生成1000个随机数 SELECT ROWNUM RN, DBMS_RANDOM.VALUE(0, 1000) RANDOM FROM DUAL CONNECT BY ROWNUM <= 1000; 注:DBMS_RANDOM.VALUE(A, B)是随机数产生函数, A是区间的开始,B是区间的结束 2. 例如:拆分以逗号隔开的 A,B,C,D 字符串 SELECT REGEXP_SUBSTR('A,B,C,D'

  • Oracle生成随机数字、字符串、日期、验证码及 UUID的方法

    在日常生活中,随机数对于我们而言并不陌生,例如手机短信验证码就是一个随机的数字字符串:对于统计分析.机器学习等领域而言,通常也需要生成大量的随机数据用于测试.数据抽样.算法验证等.那么今天我们就来谈谈如何在 Oracle 数据库中生成随机数据.

  • Oracle中的函数详解

    目录 一.数值函数 二.字符函数 三.日期时间函数 四.转换函数 五.辅助函数 六.聚合函数 七.分析函数 一.数值函数 1.mod(n1,n2):n1除以n2的余数. 如果n2为0,则返回n1. select mod(23,8),mod(24,8) from dual;--返回:7,0 2.power(n1,n2):返回数字n1的n2次幂; exp(y):返回e的y次幂.(e为数学常量); log(x,y):返回以x为底的y的对数: ln(y):返回e为底的自然对数. select power

  • 一文掌握Oracle中的Dual系统表

    这几天一直在研究Oracle,常常会用到Dual这个系统表,Dual表到底是一个什么表?带着疑问baidu了一下: Dual表是Oracle提供的最小的工作表(其实是一种虚拟表),是sys用户下的一张内部表,只有一行一列(一列:DUMMY,一列:DUMMY,其数据类型为:VARCHAR2(1)).所有用户都可以使用Dual名称访问,无论什么时候这个表总是存在.不论进行何种操作(不要删除记录),它都只有一条记录——'X'. select * from dual; 我们来查一下它的表结构,PL/SQ

  • Oracle dbca时报:ORA-12547: TNS:lost contact错误的解决

    前言 最近在工作中遇到了一个问题,错误是Oracle dbca时报错:ORA-12547: TNS:lost contact,通过查找相关的资料终于找到了解决的方法,下面分享给大家,话不多说了,来一起看看详细的介绍吧. 环境: OS:RHEL6.5 x86-64bit DB:11.2.0.4 for Linux 86-64bit 思路: DBCA报错,首先看DBCA的日志,日志中也是报ORA-12547: TNS:lost contact 于是再sqlplus / as sysdba敲回车,也是

  • Go语言排序算法之插入排序与生成随机数详解

    前言 排序,对于每种编程语言都是要面对的.这里跟大家一起分享golang实现一些排序算法,并且说明如何生成随机数.下面话不多说了,来一起看看详细的介绍吧. 经典排序算法 算法的学习非常重要,是检验一个程序员水平的重要标准.学习算法不能死记硬背,需要理解其中的思想,这样才能灵活应用到实际的开发中. 七大经典排序算法 插入排序 选择排序 冒泡排序 希尔排序 归并排序 堆排序 快速排序 插入排序 先考虑一个问题:对于长度为n的数组,前n-1位都是递增有序的,如何排序? 1.从第1位至第n-1位遍历数组

随机推荐