【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-