- 浏览: 43565 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
lost_alien:
复杂的sql恐怕用这个就够呛了。。。。
DSL-SQL源码分析 -
liaobinxu:
shaopei3344 写道递归不是会引起栈溢出吗。说说递归在 ...
递归算法 -
shaopei3344:
递归不是会引起栈溢出吗。
说说递归在现实中的例子
递归算法
由于你们公司人员的合理精简,你吸纳在身兼安全主管和数据库管理员。你想要产生一个员工及其有效的门禁卡的列表。 取决于每个雇员现在几个场所工作,
他可以有多个门禁卡,但是一次只能够有一个有效的。因为最新的门禁卡在新工作场所发出的,所以默认该卡是有效的。为了防止仿照, 门禁卡号是随机的。
你的任务是产生一个员工列表, 每个员工都是需要有关联的有效门禁卡。 使用A表示有效(Active), I表示失效(Inactive)。
方法一:
删除personel表
创建门禁卡 Badges
drop table Badges;
create table Badges(
badge_id integer not null primary key,
emp_id integer not null references personel(emp_id),
issued_date date not null,
badge_status char(1) not null check(badge_status in('A','I')),
check (1<all(select count(badge_status) from badges where badge_status='A' group by emp_id))
);
插入数据
插入 badge_id 为badge_sequence序列的nextval, issued_date为sysdate加上0-30之间的随机数
使用你一种方法将最近的门禁卡状态设为‘A’
查看状态
BADGE_ID EMP_ID TO_CHAR(ISSUED_DATE,'YYYY-MM-D BADGE_STATUS
--------------------------------------- --------------------------------------- ------------------------------ ------------
9 1 2009-03-30 19:04:32 A
4 1 2009-04-14 19:04:32 I
3 1 2009-04-01 19:04:32 I
8 2 2009-03-29 19:04:32 A
10 2 2009-04-19 19:04:32 A
2 2 2009-04-08 19:04:32 I
12 2 2009-04-12 19:04:33 A
6 3 2009-04-16 19:04:32 I
5 3 2009-03-24 19:04:32 I
1 3 2009-03-29 19:04:32 I
6 3 2009-03-25 19:04:32 I
11 3 2009-04-15 19:04:32 A
7 4 2009-04-03 19:04:32 A
13 rows selected
为了构建更新的条件
查看更新结果
BADGE_ID EMP_ID ISSUED_DATE BADGE_STATUS
--------------------------------------- --------------------------------------- ----------- ------------
2 1 2009/3/25 1 A
5 2 2009/3/30 1 I
12 2 2009/4/6 19 I
6 2 2009/4/8 19 I
3 2 2009/4/18 1 A
7 3 2009/4/11 1 I
4 3 2009/4/20 1 A
8 4 2009/3/29 1 I
10 4 2009/3/31 1 I
1 4 2009/4/7 19 I
9 4 2009/4/8 19 I
13 4 2009/4/9 19 I
11 4 2009/4/12 1 A
13 rows selected
方法2 另一方法是为门禁卡分配一顺序号,并使用min()和max()顺序号作为有效的门禁卡
删除badges
--另外创建一个badges表, 因为判断badge状态的badge_status ,该为badge_seq ,并使用min()和max()顺序号作为有效的门禁卡
现在创建视图以显示有效的门禁卡:
但门禁卡丢失后, 这个方法需要执行更新操作以复位序列号。对于这个查询不需要这样做, 但是看到序号排列好一些,而且也容易躁动每一雇员的卡总数。
这个update的意思, 同一个员工下, 相同的数据进行比较, 取个数update之前的数据
--update之后的数据
select * from badges order by badge_id, emp_id;
他可以有多个门禁卡,但是一次只能够有一个有效的。因为最新的门禁卡在新工作场所发出的,所以默认该卡是有效的。为了防止仿照, 门禁卡号是随机的。
你的任务是产生一个员工列表, 每个员工都是需要有关联的有效门禁卡。 使用A表示有效(Active), I表示失效(Inactive)。
方法一:
删除personel表
drop table personel; create table personel( emp_id integer not null primary key, emp_name varchar2(40) not null ); create sequence personel_sequence increment by 1 start with 1 nomaxvalue nocycle cache 10; //alter table personel add constraints PK_personel_emp primary key(emp_id); insert into personel values(personel_sequence.nextval,'liaobinxu'); insert into personel values(personel_sequence.nextval,'fenerdong'); insert into personel values(personel_sequence.nextval,'孙翔'); insert into personel values(personel_sequence.nextval,'谢江');
创建门禁卡 Badges
drop table Badges;
create table Badges(
badge_id integer not null primary key,
emp_id integer not null references personel(emp_id),
issued_date date not null,
badge_status char(1) not null check(badge_status in('A','I')),
check (1<all(select count(badge_status) from badges where badge_status='A' group by emp_id))
);
引用
check (1--ORA-02251: 此处不允许子查询 所以表创建失败
很多sql产品不支持表级约束使用select约束, oracle也同样, 所以去掉最后那个check
create table Badges( badge_id integer not null primary key, emp_id integer not null references personel(emp_id), issued_date date not null, badge_status char(1) not null check(badge_status in('A','I')) );
插入数据
create sequence badge_sequence increment by 1 start with 1 nomaxvalue nocycle nocache;
插入 badge_id 为badge_sequence序列的nextval, issued_date为sysdate加上0-30之间的随机数
insert into Badges(badge_id, emp_id , issued_date,Badge_Status) values(badge_sequence.nextval,round(dbms_random.value(1,4)),sysdate+round(dbms_random.value(0,30)),'I'); insert into Badges(badge_id, emp_id , issued_date,Badge_Status) values(badge_sequence.nextval,round(dbms_random.value(1,4)),sysdate+round(dbms_random.value(0,30)),'I'); insert into Badges(badge_id, emp_id , issued_date,Badge_Status) values(badge_sequence.nextval,round(dbms_random.value(1,4)),sysdate+round(dbms_random.value(0,30)),'I'); insert into Badges(badge_id, emp_id , issued_date,Badge_Status) values(badge_sequence.nextval,round(dbms_random.value(1,4)),sysdate+round(dbms_random.value(0,30)),'I'); insert into Badges(badge_id, emp_id , issued_date,Badge_Status) values(badge_sequence.nextval,round(dbms_random.value(1,4)),sysdate+round(dbms_random.value(0,30)),'I'); insert into Badges(badge_id, emp_id , issued_date,Badge_Status) values(badge_sequence.nextval,round(dbms_random.value(1,4)),sysdate+round(dbms_random.value(0,30)),'I'); insert into Badges(badge_id, emp_id , issued_date,Badge_Status) values(badge_sequence.nextval,round(dbms_random.value(1,4)),sysdate+round(dbms_random.value(0,30)),'I'); insert into Badges(badge_id, emp_id , issued_date,Badge_Status) values(badge_sequence.nextval,round(dbms_random.value(1,4)),sysdate+round(dbms_random.value(0,30)),'A'); insert into Badges(badge_id, emp_id , issued_date,Badge_Status) values(badge_sequence.nextval,round(dbms_random.value(1,4)),sysdate+round(dbms_random.value(0,30)),'A'); insert into Badges(badge_id, emp_id , issued_date,Badge_Status) values(badge_sequence.nextval,round(dbms_random.value(1,4)),sysdate+round(dbms_random.value(0,30)),'A'); insert into Badges(badge_id, emp_id , issued_date,Badge_Status) values(badge_sequence.nextval,round(dbms_random.value(1,4)),sysdate+round(dbms_random.value(0,30)),'A'); insert into Badges(badge_id, emp_id , issued_date,Badge_Status) values(badge_sequence.nextval,round(dbms_random.value(1,4)),sysdate+round(dbms_random.value(0,30)),'A'); insert into Badges(badge_id, emp_id , issued_date,Badge_Status) values(badge_sequence.nextval,round(dbms_random.value(1,4)),sysdate+round(dbms_random.value(0,30)),'A');
使用你一种方法将最近的门禁卡状态设为‘A’
查看状态
select badge_id, emp_id, to_char(issued_date,'yyyy-mm-dd hh24:mi:ss'),badge_status from badges order by emp_id;
BADGE_ID EMP_ID TO_CHAR(ISSUED_DATE,'YYYY-MM-D BADGE_STATUS
--------------------------------------- --------------------------------------- ------------------------------ ------------
9 1 2009-03-30 19:04:32 A
4 1 2009-04-14 19:04:32 I
3 1 2009-04-01 19:04:32 I
8 2 2009-03-29 19:04:32 A
10 2 2009-04-19 19:04:32 A
2 2 2009-04-08 19:04:32 I
12 2 2009-04-12 19:04:33 A
6 3 2009-04-16 19:04:32 I
5 3 2009-03-24 19:04:32 I
1 3 2009-03-29 19:04:32 I
6 3 2009-03-25 19:04:32 I
11 3 2009-04-15 19:04:32 A
7 4 2009-04-03 19:04:32 A
13 rows selected
为了构建更新的条件
update badges set badge_status='I'; update Badges set badge_status ='A'where ('I'=all(select badge_status from badges b1 where Badges.emp_id =b1.emp_id))and (issued_date=(select max(issued_date) from badges b2 where badges.emp_id =b2.emp_id))
查看更新结果
select * from badges order by emp_id, issued_date;
BADGE_ID EMP_ID ISSUED_DATE BADGE_STATUS
--------------------------------------- --------------------------------------- ----------- ------------
2 1 2009/3/25 1 A
5 2 2009/3/30 1 I
12 2 2009/4/6 19 I
6 2 2009/4/8 19 I
3 2 2009/4/18 1 A
7 3 2009/4/11 1 I
4 3 2009/4/20 1 A
8 4 2009/3/29 1 I
10 4 2009/3/31 1 I
1 4 2009/4/7 19 I
9 4 2009/4/8 19 I
13 4 2009/4/9 19 I
11 4 2009/4/12 1 A
13 rows selected
方法2 另一方法是为门禁卡分配一顺序号,并使用min()和max()顺序号作为有效的门禁卡
删除badges
drop table badges; drop sequence badge_sequence; --插入数据 create sequence badge_sequence increment by 1 start with 1 nomaxvalue nocycle nocache;
--另外创建一个badges表, 因为判断badge状态的badge_status ,该为badge_seq ,并使用min()和max()顺序号作为有效的门禁卡
create table badges ( badge_id integer not null primary key , emp_id integer not null references personel(emp_id), issued_date date not null, badge_seq integer not null check(badge_seq>0), unique(emp_id, badge_seq) ); create sequence badge_increment_sequence increment by 1 start with 1 nomaxvalue nocycle noorder; --插入 badge_id 为badge_sequence序列的nextval, -- issued_date为sysdate加上0-30之间的随机数 insert into Badges(badge_id, emp_id , issued_date,Badge_seq) values(badge_sequence.nextval,round(dbms_random.value(1,4)),sysdate+round(dbms_random.value(0,30)),badge_increment_sequence.nextval); insert into Badges(badge_id, emp_id , issued_date,Badge_seq) values(badge_sequence.nextval,round(dbms_random.value(1,4)),sysdate+round(dbms_random.value(0,30)),badge_increment_sequence.nextval); insert into Badges(badge_id, emp_id , issued_date,Badge_seq) values(badge_sequence.nextval,round(dbms_random.value(1,4)),sysdate+round(dbms_random.value(0,30)),badge_increment_sequence.nextval); insert into Badges(badge_id, emp_id , issued_date,Badge_seq) values(badge_sequence.nextval,round(dbms_random.value(1,4)),sysdate+round(dbms_random.value(0,30)),badge_increment_sequence.nextval); insert into Badges(badge_id, emp_id , issued_date,Badge_seq) values(badge_sequence.nextval,round(dbms_random.value(1,4)),sysdate+round(dbms_random.value(0,30)),badge_increment_sequence.nextval); insert into Badges(badge_id, emp_id , issued_date,Badge_seq) values(badge_sequence.nextval,round(dbms_random.value(1,4)),sysdate+round(dbms_random.value(0,30)),badge_increment_sequence.nextval); insert into Badges(badge_id, emp_id , issued_date,Badge_seq) values(badge_sequence.nextval,round(dbms_random.value(1,4)),sysdate+round(dbms_random.value(0,30)),'badge_increment_sequence.nextval); insert into Badges(badge_id, emp_id , issued_date,Badge_seq) values(badge_sequence.nextval,round(dbms_random.value(1,4)),sysdate+round(dbms_random.value(0,30)),badge_increment_sequence.nextval); insert into Badges(badge_id, emp_id , issued_date,Badge_seq) values(badge_sequence.nextval,round(dbms_random.value(1,4)),sysdate+round(dbms_random.value(0,30)),badge_increment_sequence.nextval); insert into Badges(badge_id, emp_id , issued_date,Badge_seq) values(badge_sequence.nextval,round(dbms_random.value(1,4)),sysdate+round(dbms_random.value(0,30)),badge_increment_sequence.nextval); insert into Badges(badge_id, emp_id , issued_date,Badge_seq) values(badge_sequence.nextval,round(dbms_random.value(1,4)),sysdate+round(dbms_random.value(0,30)),badge_increment_sequence.nextval); insert into Badges(badge_id, emp_id , issued_date,Badge_seq) values(badge_sequence.nextval,round(dbms_random.value(1,4)),sysdate+round(dbms_random.value(0,30)),badge_increment_sequence.nextval); insert into Badges(badge_id, emp_id , issued_date,Badge_seq) values(badge_sequence.nextval,round(dbms_random.value(1,4)),sysdate+round(dbms_random.value(0,30)),badge_increment_sequence.nextval);
现在创建视图以显示有效的门禁卡:
create view ActiveBadges(emp_id, badge_id) as select emp_id, badge_id from badges b1 where b1.badge_seq= (select max(badge_seq) from badges b2 where b1.emp_id =b2.emp_id );
但门禁卡丢失后, 这个方法需要执行更新操作以复位序列号。对于这个查询不需要这样做, 但是看到序号排列好一些,而且也容易躁动每一雇员的卡总数。
update badges set badge_seq=( select count(*) from badges b1 where badges.emp_id =b1.emp_id and badges.badge_seq>=b1.badge_seq );
这个update的意思, 同一个员工下, 相同的数据进行比较, 取个数update之前的数据
select * from badges order by badge_id, emp_id;
--update之后的数据
select * from badges order by badge_id, emp_id;
相关推荐
开源的AI自动生成SQL语句源代码,这款SQLCoder-70B-Alpha在文本到SQL的转换能力上超越了包括GPT-4在内的所有通用模型,它能更准确地理解你的需求,并生成相应的SQL查询。SQLCoder2和SQLCoder-7B模型已经向公众开放,...
标题“SQL解惑-麻醉师问题”提示我们这可能是一个关于使用SQL解决特定问题的案例,特别是与医学领域的麻醉师工作相关的数据查询或分析。在描述中提到了一个博客链接,但具体内容没有给出,不过我们可以根据标题和...
本文将深入探讨与“sql-map-2.dtd”和“sql-map-config-2.dtd”相关的知识点,以及它们在Ibatis中的作用。 Ibatis是一个轻量级的ORM(对象关系映射)框架,它允许开发者将SQL语句直接写在配置文件中,通过XML映射...
标题中的“sql解惑-跟踪投资组合问题”指的是在数据库管理中,特别是在SQL查询中解决与投资组合管理相关的复杂问题。投资组合问题通常涉及到金融数据分析,包括股票、债券和其他金融资产的投资组合表现、风险评估...
x-pack-sql-jdbc-6.4.0到x-pack-sql-jdbc-7.6.0各个版本jdbc驱动下载
x-pack-sql-jdbc-7.4.2.jar jdbc驱动包 x-pack-sql-jdbc-7.4.2.jar jdbc驱动包
最新的正式发布版sqldeveloper-21.4.3.063.0100-x64,无需安装oracle客户端,直接使用,超级方便,性能稳定,功能强大,比plsql不知强了多少,而且无盗版烦恼,全免费正版,可验证md5. MD5: 9e091ededcad4344e21c5fd...
SQL Server 2019 正式版安装引导介质,可下载ISO到本地进行安装。不支持Windows7及以下系统安装。
x-pack-sql-jdbc-6.5.4.jar
x-pack-sql-jdbc-7.4.0.jar
flume-ng-sql-source-1.5.2.jar从数据库中增量读取数据到hdfs中的jar包
elastic serach 数据库jdbc驱动。x-pack-sql-jdbc-7.5.1.jar
数据库客户端连接elasticsea rch的驱动jdbc库 x-pack-sql-jdbc-7.8.0.jar
SQLPrompt-10.14.0.4064.exe 支持SSMS 19.1
flume-ng-sql-source-1.5.1 flume连接数据库 很好用的工具
sqldeveloper-17.2.0.188.1159-x64.zip oracle mysql 数据库,适合Windows系统,可以链接mysql是一款不错的数据库x64
elasticSearch 6.8 客户端连接JAR包x-pack-sql-jdbc-6.8.0
《SQL解惑 第二版(中文)》是一本专门针对SQL语言疑难点进行解析的书籍,旨在帮助读者在实践中理解和掌握SQL的各种特性和技巧。这本书以其独特的案例解析方式,为学习SQL的人提供了一种生动、易懂的学习路径,避免...
SQLQuery1.sql-------.sql
x-pack-sql-jdbc-7.5.2是数据库客户端连接elasticsearch的驱动jdbc库