我正在尝试在我的一个应用程序上添加一项功能。这是一个示例:
公司ABC
Business hours:
Sunday closed
Monday 7am - 5pm
Tuesday 7am - 5pm
Wednesday 7am - 5pm
Thursday 7am - 5pm
Friday 7am - 5pm
Saturday closed
公司 DEF
Sunday 10am - 12pm
Monday 8am - 4pm
Tuesday 8am - 4pm
Wednesday 8am - 4pm
Thursday 8am - 4pm
Friday 8am - 4pm
Saturday closed
现在,我想做的是让我的用户能够搜索/过滤营业时间。例如,仅返回在周一下午 2 点或周六下午 1 点或周一任何时间营业的企业。
我的想法是在 SQL Server 中使用日期时间,但看来我可能需要为每天(周日到周六)创建 7 列,并为开始时间创建不同的列以打开关闭时间。
下一个想法是使这些列可搜索,以便我能够过滤它们。例如,如果用户搜索 Monday 12PM,则搜索将是 Monday (open time) <= (user search, 12pm) <= (close time)。
所以基本上,它将类似于:
SELECT *
FROM Companies
WHERE [user_search_time] IS "BETWEEN open_time AND close_time WHERE day=[user_search_day]
我很难设计这个,更不用说如何实现它了。
使用的技术是 C#/ASP.Net 和 SQL Server 2008。问题是如何使用上述技术设计/实现此功能。
任何想法/提示将不胜感激。谢谢!