oracle从几个值中随机一个数组,Oracle如何实现从特定组合中随机读取值

在这里,我们会用到DBMS_RANDOM包和CASE WHEN语句,思路如下:

一、利用DBMS_RANDOM.RANDOM函数随机生成数值,然后对数值进行取模,如果我们要在10个元素中随机读取的话,那我们需要对10进行取模。

二、再将取模后的值利用CASE WHEN语句与元素进行关联。

譬如,我有一个组合,里面包含“北京”,“上海”,“广州”,“深圳”,“武汉”五个元素,想从这五个元素中随机读取值来填充表的某个字段。

首先,创建测试表

SQL> create table test(loc varchar2(2 char));

Table created.

构造能随机读取元素的SQL语句

select case mod(abs(dbms_random.random),5)

when 1 then '北京'

when 2 then '上海'

when 3 then '广州'

when 4 then '深圳'

else '武汉' end "LOC"

from dual;

大批量填充test表的loc字段

begin

for i in 1..10 loop

insert into test values(case mod(abs(dbms_random.random),5)

when 1 then '北京'

when 2 then '上海'

when 3 then '广州'

when 4 then '深圳'

else '武汉' end );

end loop;

end;

最后生成的结果如下:

SQL> select * from test;

LOC

--------

武汉

广州

上海

北京

上海

武汉

北京

上海

武汉

深圳

10 rows selected.

0b1331709591d260c1c78e86d0c51c18.png

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值