一个sql很简单的求时间重叠数据的问题
一个sql求时间重叠数据的问题:
表结构:
Name Type Nullable Default Comments
------------ -------- -------- ------- --------
ROOM_NBR INTEGER
ARRIVAL_DATE DATE
LEAVE_DATE DATE
GUEST_NAME CHAR(30) Y
表内数据:
ROOM_NBR ARRIVAL_DATE LEAVE_DATE GUEST_NAME
1 4/1/2010 4/2/2010 A
1 4/3/2010 4/4/2010 B
2 4/1/2010 4/3/2010 C
2 4/2/2010 4/4/2010 D
现在要求求出哪个房间存在时间重叠的
希望结果:
ROOM_NBR
2
我现在的sql是:
select a.room_nbr from test_hotel a where exists
(
select 1 from test_hotel b where
a.room_nbr=b.room_nbr and
(a.arrival_date<=b.leave_date or a.leave_date>=b.arrival_date)
)
但出来的结果是
1
1
2
2
请大家告诉我,我哪里写错了