【oracle】order by dbms_random.value的含义

本文介绍了Oracle数据库中的DBMS_RANDOM包,包括其初始化过程、不同函数的功能对比,如VALUE与RANDOM函数的区别,以及如何使用这些函数进行随机排序。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

@>desc dbms_random
PROCEDURE INITIALIZE
Argument Name                  Type                    In/Out Default?
------------------------------ ----------------------- ------ --------
VAL                            BINARY_INTEGER          IN
FUNCTION NORMAL RETURNS NUMBER
FUNCTION RANDOM RETURNS BINARY_INTEGER
PROCEDURE SEED
Argument Name                  Type                    In/Out Default?
------------------------------ ----------------------- ------ --------
VAL                            BINARY_INTEGER          IN
PROCEDURE SEED
Argument Name                  Type                    In/Out Default?
------------------------------ ----------------------- ------ --------
VAL                            VARCHAR2                IN
FUNCTION STRING RETURNS VARCHAR2
Argument Name                  Type                    In/Out Default?
------------------------------ ----------------------- ------ --------
OPT                            CHAR                    IN
LEN                            NUMBER                  IN
PROCEDURE TERMINATE
FUNCTION VALUE RETURNS NUMBER
FUNCTION VALUE RETURNS NUMBER
Argument Name                  Type                    In/Out Default?
------------------------------ ----------------------- ------ --------
LOW                            NUMBER                  IN
HIGH                           NUMBER                  IN

Order By dbms_random.value ,为结果集的每一行计算一个随机数,dbms_random.value 是结果集的一个列(虽然这个列并不在select list 中),然后根据该列排序,得到的顺序自然就是随机的啦。
看看desc信息便知道vlue和random这两个函数的区别了,value返回的是number类型,并且返回的值介于1和0之间,而random返回的是BINARY_INTEGER类型(以二进制形式存储的数字,据说运算的效率高于number但我没测试过,但取值范围肯定小于number,具体限制得查资料了)
如果你要实现随机排序,还是用value函数吧

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值