【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 @   逆火狂飙  阅读(179)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(1)
历史上的今天:
2013-09-19 【Canva与图标】简约风远山红日图标
2013-09-19 【Canvas与图标】金属铝边立方红黄底黑字图像处理图标
2013-09-19 使用Spring提供Quartz来实现定时任务
生当作人杰 死亦为鬼雄 至今思项羽 不肯过江东
点击右上角即可分享
微信分享提示