--Oracle中取随机值的函数
1.dbms_random包
dbms_random包提供了一系列的随机值获取函数以及相关存储过程。下面详细讲解常用的函数和过程。
(1)dbms_random.random: --返回[-2^31, 2^31)范围内的整数随机值
(2)dbms_random.value: --返回[0,1)精度最多为38 位的数字(返回小数)
dbms_random.value (low in number,high in number): 返回为low<=result<high
(3)dbms_radnom.string(opt char,len number): 返回随机字符串
opt 是下列字符中的一个(长度只能是1):
'u', 'U' – 返回字符串是大写希腊字母
'l', 'L' – 返回字符串是小写希腊字母
'a', 'A' – 返回字符串混合大小写希腊字母
'x', 'X' – 返回字符串混合大写希腊字母和数字
'p', 'P' –返回字符串是任何可打印字符串
其他字母返回的是大写希腊字母 2.sys_guid函数: 返回32 位的16 进制表示,raw类型
SQL> select sys_guid() from dual; SYS_GUID()
--------------------------------
D0C3CDC75677446FAF9EC1C5C26A0236 对于raw类型,可以使用utl_raw包处理。
SQL> select utl_raw.cast_to_number(sys_guid()) from dual; UTL_RAW.CAST_TO_NUMBER(SYS_GUI
------------------------------
1.79662473137317E22 3.sample和sample block
(1)sample 按行的百分比来读,对于大表比较快
sample 就是读全部,不加一样sample(n),--n为[0.000001,100)当然读的也不是严格的百分比,有一定的误差。
(2)sample block:按表的块来读,按照块数目扫描
sample block中的sample不可加值,block必须加值,和单独的sample不同
sample block(n), --n为[0.000001,100) 测试:
create table test as select * from all_objects; select * from ( select * from test sample(50)) where rownum != 10;
select * from ( select * from test sample block(50) ) where rownum != 10; 有两条数据,任意删除一条
drop table test;
create table test(a number,b number);
insert into test values(1,2);
insert into test values(2,1);
delete from test where (a,b)=(select a,b from (select a,b from test order by dbms_random.value) where rownum<2);

深入理解Oracle中的随机函数的更多相关文章

  1. 理解oracle中连接和会话

    详见:http://blog.yemou.net/article/query/info/tytfjhfascvhzxcytp44 理解oracle中连接和会话 1.  概念不同:概念不同: 连接是指物 ...

  2. 彻底理解Oracle中的集合操作与复合查询

    --Oracle中的复合查询 复合查询:包含集合运算(操作)的查询 常见的集合操作有: union: 两个查询的并集(无重复行.按第一个查询的第一列升序排序) union all:两个查询的并集(有重 ...

  3. Java的JAVA_HOME、Path、CLASSPATH环境变量小结,可以借助这三个的配置去理解Oracle中的那几个环境变量的配置作用

    问题:在哪里都能执行java命令,是和JAVA_HOME变量有关系呢还是path中指定的那个java路径呢?? 刚学Java的时候,很多jdk配置教程都要求设置JAVA_HOME.Path.CLASS ...

  4. oracle中 connect by prior 递归算法 -- 理解

    oracle中 connect by prior 递归算法 -- 理解 http://blog.163.com/xxciof/blog/static/7978132720095193113752/  ...

  5. Oracle中rownum和rowid的理解

    rownum,rowid都叫伪列. 但是,rownum是逻辑上的编号,且其值总是从1开始,每行的rounum不是固定的.而rowid是“物理”编号.若数据库文件没有移动,则每行的 rowid一般是固定 ...

  6. Oracle中B-TREE索引的深入理解(转载)

    索引概述 索引与表一样,也属于段(segment)的一种.里面存放了用户的数据,跟表一样需要占用磁盘空间.只不过,在索引里的数据存放形式与表里的数据存放形式非常的不一样.在理解索引时,可以想象一本书, ...

  7. oracle中start with和connect by的用法理解

    转自:https://blog.csdn.net/qq_29274091/article/details/72627350 Oracle中start with和connect by 用法理解转自:ht ...

  8. 理解 Oracle 多租户体系中(12c,18c,19c)Grant授权作用域范围

    本篇探讨以下几个问题:你可提前猜测下面6个场景语句中,哪几个授权可以成功执行? 1. 在CDB级别中对用户进行授权,不带 container 子句的效果: 2. 在CDB级别中对用户进行授权,带 co ...

  9. [转]Oracle中Hint深入理解

    原文地址:http://czmmiao.iteye.com/blog/1478465 Hint概述 基于代价的优化器是很聪明的,在绝大多数情况下它会选择正确的优化器,减轻了DBA的负担.但有时它也聪明 ...

随机推荐

  1. HTML mate标签

    META标签分两大部分:HTTP标题信息(http-equiv)和页面描述信息(name). http-equiv http-equiv类似于HTTP的头部协议,它回应给浏览器一些有用的信息,以帮助正 ...

  2. python编程基础--计算机原理之硬件基础

    一.寄存器:寄存器是CPU内部用来存放数据的一些小型存储区域,用来暂时存放参与运算的数据和运算结果. 1.寄存器的特性: 1)寄存器位于CPU内部,数量很少,仅十四个: 2)寄存器所能存储的数据不一定 ...

  3. Django 基于session认证 小作业

    基于session认证  相亲小作业 用户登录 如果男用户登录,显示女生列表 如果女用户登录,显示男生列表 """s4day74 URL Configuration Th ...

  4. 在MySQL中使用子查询

    子查询作为数据源 子查询生成的结果集包含行.列数据,因而非常适合将它与表一起包含在from子句的子查询里.例: SELECT d.dept_id, d.name, e_cnt.how_many num ...

  5. string [] 去除重复字符两个方法

    不废话直接看图 结果 代码: this.txtListHTML.Text = String.Join(",", list.Replace("\r\n", &qu ...

  6. [LeetCode] Top K Frequent Words 前K个高频词

    Given a non-empty list of words, return the k most frequent elements. Your answer should be sorted b ...

  7. 【BZOJ 2395】Time is money

    题目大意有n个城市(编号从0..n-1),m条公路(双向的),从中选择n-1条边,使得任意的两个城市能够连通,一条边需要的c的费用和t的时间,定义一个方案的权值v=n-1条边的费用和*n-1条边的时间 ...

  8. 2015 多校联赛 ——HDU5302(矩阵快速幂)

    The Goddess Of The Moon Sample Input 2 10 50 12 1213 1212 1313231 12312413 12312 4123 1231 3 131 5 5 ...

  9. 【bzoj4571&&SCOI2016美味】

    4571: [Scoi2016]美味 Time Limit: 30 Sec  Memory Limit: 256 MBSubmit: 656  Solved: 350[Submit][Status][ ...

  10. mycat 1.6 简单的操作实例

    环境: centos7.4 + mysql5.7.20 + mycat1.6单台主机上安装了5台mysql_5.7.20 实例(3306,3307,3308,3309,3310)3306为独立实例 ( ...