【Oracle】给雇员表的职业字段赋上五选一的随机职业(科学家、医生、警察、工人、码农里五选一)

需求:创建一个雇员表,要求其职业occupation字段是五种职业:科学家、医生、警察、工人、码农里面的一个。

实现:

先准备一个种子表存职业信息:

create table seed(
id int,
name nvarchar2(10),
primary key(id));

充值:

insert into seed values(1,'科学家');
insert into seed values(2,'医生');
insert into seed values(3,'警察');
insert into seed values(4,'工人');
insert into seed values(5,'码农');

 

第二步创建雇员表:

create table emp2(
id number(6),
name nvarchar2(20),
occupation nvarchar2(20),
seed number(6),
primary key(id));

充值:

insert into emp2
select 
     rownum,
     dbms_random.string('*',dbms_random.value(6,20)),
     '',
     dbms_random.value(1,5)
from 
     dual
connect by level<11;

 

第三步也就是最关键的一步,用seed表里的值去更新occupation字段

update emp2 a set occupation=(select name from seed b where b.id=a.seed) where 1=1;

 

结果:

SQL> update emp2 a set occupation=(select name from seed b where b.id=a.seed) where 1=1;

已更新10行。

SQL> select * from emp2;

        ID NAME                 OCCUPATION                                     SEED
---------- -------------------- ---------------------------------------- ----------
         1 RDTLXBYSVG           科学家                                            1
         2 YLYPKQNPAHASCTGH     工人                                              4
         3 MUXMPVUYBOH          医生                                              2
         4 HDAUSLRDEL           医生                                              2
         5 TWZTQLKNSSQOSKAESZVX 医生                                              2
         6 VLOKKMDQLO           工人                                              4
         7 JMFJOHAZWANA         码农                                              5
         8 KMBITBLIGJGU         科学家                                            1
         9 BMEZAYTPMSYRYRIVWY   工人                                              4
        10 VWRWWAVPGGGQ         工人                                              4

已选择10行。

 

到这里就达成需求了,其实关键是给emp2表加上seed字段并赋上1-5的随机值的一步,其它都还平常。

网上传的 select name from (select name from seed order by dbms_random.value) where rownum<2 如果放在insert into emp2 select...的第三行会导致职业都是一样的,而update emp2 a set occupation=(select name from (select name from seed order by dbms_random.value) where rownum<2) where 1=1; 也会导致职业是一样的结果,这就不符合需求了。

-END-

posted @ 2021-09-19 19:27  逆火狂飙  阅读(163)  评论(0编辑  收藏  举报
生当作人杰 死亦为鬼雄 至今思项羽 不肯过江东