【SQL练习】要求编写SQL语句查询20061231对应的上一工作日日期。

在这里插入图片描述

create table tab11 (
       wrcvdate number,
       year number(4),
       month number(2),
       day number(2),
       flag number(1)
);

insert into tab11 (wrcvdate, year, month, day, flag) 
values (20061228, 2016, 12, 28, 1);
insert into tab11 (wrcvdate, year, month, day, flag) 
values (20061229, 2016, 12, 29, 1);
insert into tab11 (wrcvdate, year, month, day, flag) 
values (20061230, 2016, 12, 30, 0);
commit;
select max(t.wrcvdate) 上一个工作日日期 from tab11 t where t.flag = 1 and t.wrcvdate < 20061231;

1.wrcvdate < 20061231:筛选所有早于20061231的日期。

2.flag = 1:仅选择工作日(flag=1)。

3.MAX(wrcvdate):取这些工作日中最接近20061231的日期(即上一个工作日)。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值