面试题整理:SQL(二)

1.

现有广告合同表Orders,表示广告在哪个广告位的哪几天需要播出

OrderID

Positioncode

Startdate

Enddate

1

A

2015-11-01

2015-11-03

2

C

2015-11-02

2015-11-03

3

B

2015-11-01

2015-11-04

4

A

2015-11-03

2015-11-04

5

C

2015-11-01

2015-11-02

6

B

2015-11-02

2015-11-05

7

A

2015-11-02

2015-11-03

8

A

2015-11-04

2015-11-05

9

C

2015-11-03

2015-11-04

10

C

2015-11-02

2015-11-04

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

产品表 Product,表示每个广告位每天最多播几个广告

Positioncode

Showcount

A

2

B

1

C

3

 

 

 

 

 

 

要求查询出合同表中,超过广告位轮播数量的合同

 

Declare @Dup table (TmpDate datetime) 
Declare @minDate datetime,@maxDate datetime 
SELECT @minDate=MIN(StartDate),@maxDate=Max(EndDate) FROM Orders 
WHILE @minDate<=@MaxDate 
BEGIN 
INSERT INTO @Dup VALUES (@minDate) 
SET @minDate=@minDate+1 
END 

SELECT distinct aa.* FROM 
Orders aa INNER JOIN ( 
SELECT Positioncode,tmpdate,count(*) as cnt 
FROM Orders a,@Dup b 
where tmpdate between a.startdate and a.enddate 
group by Positioncode,tmpdate )bb 
ON aa.PositionCode=bb.PositionCode AND bb.tmpDate Between aa.StartDate AND aa.ENdDate 
INNER JOIN Product cc ON bb.PositionCode=cc.PositionCode 
WHERE bb.cnt>cc.showcount
Order by PositionCode

 

OrderId  PositionCode  StartDate  EndDate  
1A2015-11-012015-11-03
4A2015-11-032015-11-04
7A2015-11-022015-11-03
3B2015-11-012015-11-04
6B2015-11-022015-11-05

 

 

 

 

 

 

2.

请用SQL语句实现:从T_GetLargerDebitOccur数据表中查询出所有月份的发生额都比101科目相应月份的发生额高的记录。

请注意:该表中有很多科目,都有1-12月份的发生额。 

  AccID:科目代码,Occmonth:发生额月份,  DebitOccur:发生额。

AccId  Occmonth  DebitOccur  
1011100
1021200
1031300
1012400
1022300
1032500
1013300
1043400
NULLNULLNULL

 

 

 

 

 

 

 

 

 

select a.*  from T_GetLargerDebitOccur a  
,(select Occmonth,max(DebitOccur) Debit101ccur from T_GetLargerDebitOccur where AccID='101' group by Occmonth) b  
where a.Occmonth=b.Occmonth and a.DebitOccur>b.Debit101ccur

 

结果:

AccId  Occmonth  DebitOccur  
1021200
1031300
1042500
1053400

 

 

 

 

 

 

 

 

 

 

 

To be continue...

 

转载于:https://www.cnblogs.com/alex09/p/4741273.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值