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

文章作者 100test 发表时间 2007:05:07 15:46:33
来源 100Test.Com百考试题网


在你的工作中是否会为了某个活动要随机取出一些符合条件的EMAIL或者手机号码用户,来颁发获奖通知或其它消息?
  
  如果是的话,可以用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 0select tmp_id.nextval as id,email,mobileno from 表名 where 条件.
  
  找到最大的id号:
  
  0select 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)).

相关文章


让SQLServer为工作负载高峰提前做好准备
为何选择DB29数据库XML成为靓点
Oracle里取随机数的几种具体的方法
详细讲述Oracle密码丢失解决方法
oracle下导出某用户所有表的方法
[1Z0-031]我的考试经验总结
分析Oracle下导出某用户所有表的方法
澳大利亚华人论坛
考好网
日本华人论坛
华人移民留学论坛
英国华人论坛