SQL SERVER中有关时间区间的查询问题

lxl 2005-04-10 01:37:52
表A有如下字段:
酒店顾客ID号、现住房间号,入住日期,离开日期(如果还没走的,就用GETDATE()作为离开日期)

表B中放置顾客的换房间记录(少数情况,但有记录),有如下字段:
酒店顾客ID号、原房间号,现房间号,换房日期

现要统计从某一天@frm 到 另一天@to 中,每个房间处于“有人入住”的状态的总天数

得到的查询格式应该如下:
处于“有人入住”的总天数 房间利用率
A 房 10 50%
B 房 20 100%
C 房 5 25%
D 房 15 75%

谢谢指教
...全文
497 18 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
18 条回复
切换为时间正序
请发表友善的回复…
发表回复
lxl 2005-04-11
  • 打赏
  • 举报
回复
不是呀,如果一个人从4月1日到5日住2001房,6日换到了2002房,我的设计只保留一条记录,因为要用于调出顾客信息来进行顾客的记帐等操作,也就是把当前的2001换成2002,换房的信息只保留在换房记录表内
TechnoFantasy 2005-04-11
  • 打赏
  • 举报
回复
不会的吧,顾客换房了应该是产生一个新的记录吧。假设一个人从4月1日到5日住2001房,6日换到了2002房,那么就应该有至少两条记录。你只要在计算的时候group by 房间号应该就可以了啊。
luxuewei5214 2005-04-11
  • 打赏
  • 举报
回复
xuexi...
lxl 2005-04-11
  • 打赏
  • 举报
回复
如果是这样的话,那么就没法通过这一个表来获取某个房间一定时间的使用率了,因为在顾客换房以后原来的房间号在这个表里面已经没有表示了。估计你需要根据换房记录表的结构联立换房记录表。

是的,所说的表B正是此项数据
liuxingstar 2005-04-11
  • 打赏
  • 举报
回复
我认为,楼主要记录的主体是 客房,而楼主给出的两个表的主体是客人。相关性不是很大。
楼主是否考虑应该从新建立一个房间的表,每天为一个记录, 每年 或几年为一个周期。这样统计时
之间用时间就可以了。
节省很多步骤
mib3000 2005-04-11
  • 打赏
  • 举报
回复
up
TechnoFantasy 2005-04-11
  • 打赏
  • 举报
回复
如果是这样的话,那么就没法通过这一个表来获取某个房间一定时间的使用率了,因为在顾客换房以后原来的房间号在这个表里面已经没有表示了。估计你需要根据换房记录表的结构联立换房记录表。
max8max 2005-04-10
  • 打赏
  • 举报
回复
明白楼主的心情,帮顶
lxl 2005-04-10
  • 打赏
  • 举报
回复
还不是我要的结果,因为我要的是分房间的统计,而且顾客又不一定总在一个房间住(也就是说不能用当前所住的房间来考虑),还要把换房的情况考虑进去
lxl 2005-04-10
  • 打赏
  • 举报
回复
不过没关系,因为结果是负数,可以筛掉
lxl 2005-04-10
  • 打赏
  • 举报
回复
晕,发现
TechnoFantasy(冰儿马甲www.applevb.com) 有方法有一个缺陷,就是如果顾客的离开日期和入住日期的时间段,和 @frm 及 @to 之间根本没有任何重合,也会统计出结果
lxl 2005-04-10
  • 打赏
  • 举报
回复
多谢 TechnoFantasy(冰儿马甲www.applevb.com)
sum(GetDays(getSmallerDay(离开日期, @to)-getBiggerDay(入住日期, @from)))
这个方法很有效,但还不是我要的结果,因为我要的是分房间的统计,而且顾客又不一定总在一个房间住(也就是说不能用当前所住的房间来考虑),还要把换房的情况考虑进去
纯冰糖 2005-04-10
  • 打赏
  • 举报
回复
Study
todouwang 2005-04-10
  • 打赏
  • 举报
回复
先比较入住日期,@from
离开日期,@to的早晚关系
TechnoFantasy 2005-04-10
  • 打赏
  • 举报
回复
可以用一个过程来判断一下,把sum(GetDays(离开日期-入住日期))改成:

sum(GetDays(getSmallerDay(离开日期, @to)-getBiggerDay(入住日期, @from)))

getSmallerDay、getBiggerDay分别返回两个日期中比较早的和比较晚的一个。
lxl 2005-04-10
  • 打赏
  • 举报
回复
关注也会给分
lxl 2005-04-10
  • 打赏
  • 举报
回复
多谢楼上,但是忽略了一种情况,就是
sum(GetDays(离开日期-入住日期)) 并不一定等于 有人入住总天数
因为离开日期和入住日期,可能仅有一部分时间段,和 @frm 及 @to 之间重合,有时入住日期比
@frm要早,或入住日期比@to 要晚,这样统计出来的(离开日期-入住日期),就不是在@frm 到 另一天@to 天中所占的天数。
僵哥 2005-04-10
  • 打赏
  • 举报
回复
楼主这是流水帐的管理模式吧?

基本处理如下(未考虑换房):
----------------------------------
select 现住房间号,
sum(GetDays(离开日期-入住日期)) as 有人入住总天数,
cast(sum(GetDays(离开日期-入住日期))*100/GetDays(@to-@frm) as varchar 3)+'%' --包含性质的天数还应该+1
where 入住日期>=@frm and 离开日期<=@to
group by 现住房间号
----------------------------------

2,507

社区成员

发帖
与我相关
我的任务
社区描述
Delphi 数据库相关
社区管理员
  • 数据库相关社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧