【C#】根据开始时间和结束时间筛选存在的信息
2020-07-17 23:57
901 查看
背景
业务需求中,需要根绝开始时间和结束时间筛选一段时间内的任务存在个数。
示例图片
根据开始时间 9:00到 结束时间11:00 筛选信息
总共有这么四种情况可能出现
插入测试数据
CREATE TABLE [dbo].[Schedule] ( [ScheduleId] int NOT NULL IDENTITY(1,1) , [ScheduleTheme] nvarchar(100) NOT NULL , [ScheduleContent] nvarchar(500) NULL , [ScheduleBeginTime] datetime NULL , [ScheduleEndTime] datetime NULL , [CreateTime] datetime NULL ) INSERT INTO [Demo].[dbo].[Schedule] ( [ScheduleTheme], [ScheduleContent], [ScheduleBeginTime], [ScheduleEndTime], [CreateTime] ) VALUES ('测试标题001', '', '2020-07-04 10:00:00', '2020-07-08 11:00:00', GETDATE()); INSERT INTO [Demo].[dbo].[Schedule] ( [ScheduleTheme], [ScheduleContent], [ScheduleBeginTime], [ScheduleEndTime], [CreateTime] ) VALUES ('测试标题001', '', '2020-07-06 10:00:00', '2020-07-09 11:00:00', GETDATE()); INSERT INTO [Demo].[dbo].[Schedule] ( [ScheduleTheme], [ScheduleContent], [ScheduleBeginTime], [ScheduleEndTime], [CreateTime] ) VALUES ('测试标题001', '', '2020-07-04 10:00:00', '2020-07-06 11:00:00', GETDATE()); INSERT INTO [Demo].[dbo].[Schedule] ( [ScheduleTheme], [ScheduleContent], [ScheduleBeginTime], [ScheduleEndTime], [CreateTime] ) VALUES ('测试标题001', '', '2020-07-06 10:00:00', '2020-07-06 11:00:00', GETDATE()); INSERT INTO [Demo].[dbo].[Schedule] ( [ScheduleTheme], [ScheduleContent], [ScheduleBeginTime], [ScheduleEndTime], [CreateTime] ) VALUES ('测试标题001', '', '2020-07-01 10:00:00', '2020-07-04 11:00:00', GETDATE()); INSERT INTO [Demo].[dbo].[Schedule] ( [ScheduleTheme], [ScheduleContent], [ScheduleBeginTime], [ScheduleEndTime], [CreateTime] ) VALUES ('测试标题001', '', '2020-07-08 10:00:00', '2020-07-14 11:00:00', GETDATE());
示例LINQ 代码
var beginDate=new DateTime(“2020-07-07”); var endDate=new DateTime(“2020-07-07”); var tasks = demo.Where(n => (n.ScheduleBeginTime > endDate && n.ScheduleBeginTime > beginDate)|| (n.ScheduleBeginTime > beginDate && n.ScheduleEndTime < endDate) || (n.ScheduleEndTime < endDate && n.ScheduleEndTime > beginDate) || (n.ScheduleEndTime > endDate && n.ScheduleBeginTime < beginDate);
sql 示例
SELECT * FROM Schedule WHERE 1!=1 or (ScheduleBeginTime < '2020-07-07' AND ScheduleBeginTime > '2020-07-05') --查询1种情况 or (ScheduleBeginTime > '2020-07-05' AND ScheduleEndTime < '2020-07-07' ) --查询2种情况 or (ScheduleEndTime < '2020-07-07' AND ScheduleEndTime > '2020-07-05') --查询3种情况 or (ScheduleEndTime > '2020-07-07' AND ScheduleBeginTime < '2020-07-05') --查询4种情况
相关文章推荐
- C# 根据第几周和季度 获取开始时间和结束时间
- 根据开始、结束时间获取工作日天数及根据开始时间、工作日天数获取截止日期(数据库存储节假日信息)
- C#获取指定月指定周的日期范围 根据当前时间获取本月开始日期和结束日期
- C#获取指定月指定周的日期范围 根据当前时间获取本月开始日期和结束日期
- C#获取指定月指定周的日期范围 根据当前时间获取本月开始日期和结束日期的代码
- C#获取指定月指定周的日期范围 根据当前时间获取本月开始日期和结束日期
- C#获取指定月指定周的日期范围 根据当前时间获取本月开始日期和结束日期
- C# 获取两个时间段之间的所有时间与获取当前时间所在的季度开始和结束时间
- 根据开始时间和结束时间获取年,月,日,小时列表
- Scala根据开始时间和结束时间,把这个时间段所有的时间都列出来
- DB2怎么根据开始和结束时间算相隔天数
- Java根据开始时间和结束时间返回时间段内的时间集合
- (根据指定时间)动态划分学期分表,用以动态学期分表自动CURD等联动操作(开始结束时间可修改-待完善待修改)
- laydate如何根据开始时间或者结束时间限制范围
- 根据开始时间和结束时间返回时间段内的时间集合
- c# 获取 本周、本月、本季度、本年 的开始时间或结束时间
- 根据开始和结束时间,计算出该时间段每个星期的开始和结束时间
- java根据开始时间结束时间计算中间间隔日期
- java根据开始时间结束时间计算中间间隔日期的实例代码
- SqlServer 根据开始结束小时查询每个小时的时间