zoukankan      html  css  js  c++  java
  • 【C#】根据开始时间和结束时间筛选存在的信息

    背景

    业务需求中,需要根绝开始时间和结束时间筛选一段时间内的任务存在个数。

    示例图片

    根据开始时间 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种情况
    
    
  • 相关阅读:
    .NET中常用获取程序根目录的方法
    多态的实现
    9个优秀网上免费标签云生成工具
    Asp.Net自定义错误页心得介绍
    C# string.Format 格式化使用说明
    接口编程,反射创建对象
    DllImport使用的一点整理
    System.Data.ConstraintException: 未能启用约束。一行或多行中包含违反非空、唯一或外键约束的值。
    C# OleDb读取Excel文件 避免出现 科学计数法 的列
    C++翻译C#
  • 原文地址:https://www.cnblogs.com/sopcce/p/StartTime_and_EndTime_filter_existing_information.html
Copyright © 2011-2022 走看看