Oracle里取随机数的几种具体的方法
来源:优易学  2010-1-11 17:36:22   【优易学:中国教育考试门户网】   资料下载   IT书店
  在你的工作中是否会为了某个活动要随机取出一些符合条件的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 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'));

责任编辑:cyth

文章搜索:
 相关文章
热点资讯
热门课程培训