深入理解Oracle中的随机函数
--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中的随机函数的更多相关文章
- 理解oracle中连接和会话
详见:http://blog.yemou.net/article/query/info/tytfjhfascvhzxcytp44 理解oracle中连接和会话 1. 概念不同:概念不同: 连接是指物 ...
- 彻底理解Oracle中的集合操作与复合查询
--Oracle中的复合查询 复合查询:包含集合运算(操作)的查询 常见的集合操作有: union: 两个查询的并集(无重复行.按第一个查询的第一列升序排序) union all:两个查询的并集(有重 ...
- Java的JAVA_HOME、Path、CLASSPATH环境变量小结,可以借助这三个的配置去理解Oracle中的那几个环境变量的配置作用
问题:在哪里都能执行java命令,是和JAVA_HOME变量有关系呢还是path中指定的那个java路径呢?? 刚学Java的时候,很多jdk配置教程都要求设置JAVA_HOME.Path.CLASS ...
- oracle中 connect by prior 递归算法 -- 理解
oracle中 connect by prior 递归算法 -- 理解 http://blog.163.com/xxciof/blog/static/7978132720095193113752/ ...
- Oracle中rownum和rowid的理解
rownum,rowid都叫伪列. 但是,rownum是逻辑上的编号,且其值总是从1开始,每行的rounum不是固定的.而rowid是“物理”编号.若数据库文件没有移动,则每行的 rowid一般是固定 ...
- Oracle中B-TREE索引的深入理解(转载)
索引概述 索引与表一样,也属于段(segment)的一种.里面存放了用户的数据,跟表一样需要占用磁盘空间.只不过,在索引里的数据存放形式与表里的数据存放形式非常的不一样.在理解索引时,可以想象一本书, ...
- oracle中start with和connect by的用法理解
转自:https://blog.csdn.net/qq_29274091/article/details/72627350 Oracle中start with和connect by 用法理解转自:ht ...
- 理解 Oracle 多租户体系中(12c,18c,19c)Grant授权作用域范围
本篇探讨以下几个问题:你可提前猜测下面6个场景语句中,哪几个授权可以成功执行? 1. 在CDB级别中对用户进行授权,不带 container 子句的效果: 2. 在CDB级别中对用户进行授权,带 co ...
- [转]Oracle中Hint深入理解
原文地址:http://czmmiao.iteye.com/blog/1478465 Hint概述 基于代价的优化器是很聪明的,在绝大多数情况下它会选择正确的优化器,减轻了DBA的负担.但有时它也聪明 ...
随机推荐
- Oracle update 执行更新操作后的数据恢复
操作数据库,经常会出现误操作,昨天执行的更新操作之后发现更新错了,只能想办法数据恢复了,现在整理一下 第一步:查询执行更新操作的时间 select r.FIRST_LOAD_TIME,r.* from ...
- 其实你并不懂如何定义一个 PHP 函数
<?php function divide($dividend, $divisor){ return $dividend / $divisor; } echo divide(12, 4); ec ...
- Sublime Text3 运行Python 出现Error:Decode error - output not utf-8
问题描述: Sublime Text 3 在build Python时,如果python源代码输出有中文,例如"print('中文')",Sublime Text 会报 [Deco ...
- Java基础语法<六> 数组 Arrays
笔记整理 来源于<Java核心技术卷 I > <Java编程思想> 允许数组长度为0 new element[0] 数组长度为0与null不同 1. 数组拷贝 允许将一 ...
- Java面试题—初级(2)
11.是否可以从一个static方法内部发出对非static方法的调用? 不可以.因为非static方法是要与对象关联在一起的,必须创建一个对象后,才可以在该对象上进行方法调用,而static方法调用 ...
- ORACLE数据库编程
第一章 Oracle数据库基本概念 一.介绍 Oracle数据库系统是美国Oracle(甲骨文)公司提供的以分布式数据库为 核心的一组软件产品,是目前最流行的客户/服务器(Client/Server, ...
- ES6 new syntax of Rest and Spread Operators
Rest and Spread Operators.md Why we need rest and spread operators? var showCollections = function(i ...
- drupal 8 查看数据库用户名密码
一.查看网站数据库名.密码 在已安装网站下 例如:我安装了一个d8radix的网站,此网站/home/jx/www/d8radix/sites/default/setting.php文件里面 数据库名 ...
- [ Java学习基础 ] Java对象的创建和销毁
类实例化可生成对象,实例方法就是对象方法,实例变量就是对象属性.一个对象的生命周期包括三个阶段:创建.使用和销毁. 创建对象 创建对象包括两个步骤:声明和实例化. 声明 声明对象与声明普通变量没有区别 ...
- kmp——cogs 1570 乌力波
1570. [POJ3461]乌力波 ★☆ 输入文件:oulipo.in 输出文件:oulipo.out 简单对比 时间限制:1 s 内存限制:256 MB [题目描述] 法国作家乔治 ...