Oracle 随机函数 DBMS_RANDOM

WBOY
풀어 주다: 2016-06-07 16:49:13
원래의
1101명이 탐색했습니다.

最近在给公司开发人员造数据,这些数据要随机范围的,就用到了DBMS_RANDOM函数。这个函数不光能造一些随机数字,还能随机造一些日

最近在给公司开发人员造数据,这些数据要随机范围的,就用到了DBMS_RANDOM函数。这个函数不光能造一些随机数字,还能随机造一些日期|字符等。

DBMS_RANDOM在官方文档的 PL/SQL Packages and Types Reference-->75 DBMS_RANDOM这个位置。

Oracle 随机函数 DBMS_RANDOM

--------------------------------------分割线 --------------------------------------

生成动态前缀且自增号码的Oracle函数

Spring StoredProcedure调用Oracle函数各种异常解决方法

Oracle函数之case和decode的用法区别及性能比较

Oracle函数wmsys.wm_concat的使用

SQL中Oracle函数列表速查

--------------------------------------分割线 --------------------------------------

1.产生随机数字

SQL> SELECT DBMS_RANDOM.VALUE FROM DUAL;

    VALUE
----------
.360532538

SQL> SELECT DBMS_RANDOM.VALUE(0, 100) FROM DUAL;

      DBMS_RANDOM.VALUE(0,100)
-------------------------------
                    26.8474818

这个函数在默认下回产生0-1之间的小数,如果加入参数的话,会产生参数之间的小数

2.产生整数

SQL> SELECT TRUNC(DBMS_RANDOM.VALUE(0, 100)) FROM DUAL;

TRUNC(DBMS_RANDOM.VALUE(0,100))
-------------------------------
                            57

SQL> SELECT TRUNC(DBMS_RANDOM.VALUE(0, 100)) FROM DUAL;

TRUNC(DBMS_RANDOM.VALUE(0,100))
-------------------------------
                            34

3.产生随机日期

SQL> SELECT TO_CHAR(TO_DATE('2014-01-02','yyyy-mm-dd'),'J')FROM DUAL;

TO_CHAR(TO_DATE('2014
---------------------
2456660

SQL> SELECT to_char(to_date(TRUNC(DBMS_RANDOM.VALUE(2456660,2456660+180)),'j'),'yyyy-mm-dd') FROM DUAL;

TO_CHAR(TO_DATE(TRUNC(DBMS_RAN
------------------------------
2014-02-24

SQL> SELECT to_char(to_date(TRUNC(DBMS_RANDOM.VALUE(2456660,2456660+180)),'j'),'yyyy-mm-dd') FROM DUAL;

TO_CHAR(TO_DATE(TRUNC(DBMS_RAN
------------------------------
2014-02-28

上面的意思是 ,想要2014-01-02以后180以内随机的日期,先计算出2014-01-02那天对应的oracle内部日期数,,然后根据这个计算便宜量。

4.随机字符

SQL> SELECT DBMS_RANDOM.STRING('A', 20) FROM DUAL;

DBMS_RANDOM.STRING('A',20)
--------------------------------------------------------------------------------
egNhrpzmklLVUWHMNPbb

SQL> SELECT DBMS_RANDOM.STRING('A', 20) FROM DUAL;

DBMS_RANDOM.STRING('A',20)
--------------------------------------------------------------------------------
IlMlBgNlvqwaufbTJxHN

SQL> SELECT DBMS_RANDOM.STRING('U',20) FROM DUAL;

DBMS_RANDOM.STRING('U',20)
--------------------------------------------------------------------------------
DLAMFMWNWWUEXOAQGNJT

SQL> SELECT DBMS_RANDOM.STRING('U',20) FROM DUAL;

DBMS_RANDOM.STRING('U',20)
--------------------------------------------------------------------------------
QYGPITUPJHMKTOAKFCGX

SQL> SELECT DBMS_RANDOM.STRING('L',20)  FROM DUAL;

DBMS_RANDOM.STRING('L',20)
--------------------------------------------------------------------------------
nbxvjzdddxduwkvmfubp

SQL> SELECT DBMS_RANDOM.STRING('L',20)  FROM DUAL;

DBMS_RANDOM.STRING('L',20)
--------------------------------------------------------------------------------
ujyqkuocrhouphozxktm

SQL>

‘U’用来生成大写字符
‘L’用来生成小写字符
‘A’用来生成大小写混合的字符

本文永久更新链接地址:

linux

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!