深入理解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的负担.但有时它也聪明 ...
随机推荐
- XML之XPath
1.在 XPath 中,有七种类型的节点:元素.属性.文本.命名空间.处理指令.注释以及文档节点(或称为根节点). 1.1 XPath 术语 节点(Node) 在 XPath 中,有七种类型的节点:元 ...
- Django 使用celery任务队列的配置
celery 情景:用户发起request,并等待response返回.在本些views中,可能需要执行一段耗时的程序,那么用户就会等待很长时间,造成不好的用户体验,比如发送邮件.手机验证码等. 使用 ...
- 判断一个字符串是不是一个合法的IP地址
最近在笔试的时候遇到碰一道算法题, 要求判断一个字符串是不是合法的ip地址. 将我的思路发出来分享一下,不一定正确,也不一定是最优的方法.希望能分享一些交流 要求用java或者c来实现,我的java代 ...
- WebStorm2018破解
参考网站http://www.sdbeta.com/wg/2018/0302/220048.html修改整理如下: webstorm 2018.1正式版破解summary jetbrainscrack ...
- Struts(十四):通用标签-form表单
form标签是struts2标签中一个重要标签: 可以生成html标签,使用起来和html的form标签差不多: Strut2的form标签会生成一个table,进行自动布局: 可以对表单提交的值进行 ...
- 框架学习之Struts2(三)---OGNL和值栈
一.OGNL概述 1.1OGNL是对象图导航语言(Object-Graph Navigation Languaged)的缩写,他是一种功能强大的表达式语言,通过简单一致的表达式语法,可以存取Java对 ...
- POJ-3617 Best Cow Line---字符串贪心
题目链接: https://vjudge.net/problem/POJ-3617 题目大意: 每次都可以从字符串的首部或者尾部提取字母,使得最后的字符串的字典序最小. 思路: 贪心做即可~每次从上和 ...
- [论文阅读]Going deeper with convolutions(GoogLeNet)
本文采用的GoogLenet网络(代号Inception)在2014年ImageNet大规模视觉识别挑战赛取得了最好的结果,该网络总共22层. Motivation and High Level Co ...
- CAdvisor container monitor
Now cadvisor is useful as a container montor tool. Not only it can monitor many container level metr ...
- [LeetCode] Complex Number Multiplication 复数相乘
Given two strings representing two complex numbers. You need to return a string representing their m ...