--Createdat" />

亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

SQL 判斷兩個時間段是否有交叉

系統 2105 0

費話不說,直接上代碼

SQL 代碼:

View Code
        
          IF
        
        
          EXISTS
        
         (
        
          SELECT
        
        
          *
        
        
          FROM
        
         sys.objects 
        
          WHERE
        
        
          object_id
        
        
          =
        
        
          OBJECT_ID
        
        (N
        
          '
        
        
          [dbo].[fun_GetTimeSlotDays]
        
        
          '
        
        
          ))


        
        
          DROP
        
        
          FUNCTION
        
        
          [
        
        
          dbo
        
        
          ]
        
        
          .fun_GetTimeSlotDays


        
        
          GO
        
        
          --
        
        
           =============================================
        
        
          

--
        
        
           Author:        <Mike.Jiang>
        
        
          

--
        
        
           Create date: <2012-07-18>
        
        
          

--
        
        
           Description:    <判斷兩個時間斷是否有交叉,如果有則返回1,否則返回0>
        
        
          

--
        
        
           =============================================
        
        
          CREATE
        
        
          FUNCTION
        
        
           dbo.fun_GetTimeSlotDays(


        
        
          @fromDate
        
        
          DATETIME
        
        
          ,


        
        
          @toDate
        
        
          DATETIME
        
        
          ,


        
        
          @startDate
        
        
          DATETIME
        
        
          ,


        
        
          @endDate
        
        
          DATETIME
        
        
          

)


        
        
          RETURNS
        
        
          INT
        
        
          AS
        
        
          BEGIN
        
        
          DECLARE
        
        
          @ret
        
        
          INT
        
        
          ;

   
        
        
          IF
        
        (
        
          DATEDIFF
        
        (
        
          DAY
        
        ,
        
          @fromDate
        
        ,
        
          @endDate
        
        )
        
          >=
        
        
          0
        
        
          AND
        
        
          DATEDIFF
        
        (
        
          DAY
        
        ,
        
          @endDate
        
        ,
        
          @toDate
        
        )
        
          >=
        
        
          0
        
        
           )

      
        
        
          SET
        
        
          @ret
        
        
          =
        
        
          1
        
        
          ;

   
        
        
          IF
        
        (
        
          DATEDIFF
        
        (
        
          DAY
        
        ,
        
          @startDate
        
        ,
        
          @toDate
        
        )
        
          >=
        
        
          0
        
        
          AND
        
        
          DATEDIFF
        
        (
        
          DAY
        
        ,
        
          @toDate
        
        ,
        
          @endDate
        
        )
        
          >=
        
        
          0
        
        
           )

      
        
        
          SET
        
        
          @ret
        
        
          =
        
        
          1
        
        
          ;

   
        
        
          IF
        
         (
        
          @ret
        
        
          is
        
        
          null
        
        
          )

      
        
        
          SET
        
        
          @ret
        
        
          =
        
        
          0
        
        
          ;

   
        
        
          RETURN
        
        
          @ret
        
        
          ;


        
        
          END
        
        
          GO
        
      

?

測試代碼:

      
        SELECT
      
       dbo.fun_GetTimeSlotDays(
      
        '
      
      
        2012-03-01
      
      
        '
      
      ,
      
        '
      
      
        2012-03-10
      
      
        '
      
      ,
      
        '
      
      
        2012-02-10
      
      
        '
      
      ,
      
        '
      
      
        2012-02-20
      
      
        '
      
      
        );


      
      
        SELECT
      
       dbo.fun_GetTimeSlotDays(
      
        '
      
      
        2012-03-01
      
      
        '
      
      ,
      
        '
      
      
        2012-03-10
      
      
        '
      
      ,
      
        '
      
      
        2012-02-01
      
      
        '
      
      ,
      
        '
      
      
        2012-03-01
      
      
        '
      
      
        );


      
      
        SELECT
      
       dbo.fun_GetTimeSlotDays(
      
        '
      
      
        2012-03-01
      
      
        '
      
      ,
      
        '
      
      
        2012-03-10
      
      
        '
      
      ,
      
        '
      
      
        2012-03-01
      
      
        '
      
      ,
      
        '
      
      
        2012-03-02
      
      
        '
      
      
        );


      
      
        SELECT
      
       dbo.fun_GetTimeSlotDays(
      
        '
      
      
        2012-03-01
      
      
        '
      
      ,
      
        '
      
      
        2012-03-10
      
      
        '
      
      ,
      
        '
      
      
        2012-03-10
      
      
        '
      
      ,
      
        '
      
      
        2012-03-11
      
      
        '
      
      
        );


      
      
        SELECT
      
       dbo.fun_GetTimeSlotDays(
      
        '
      
      
        2012-03-01
      
      
        '
      
      ,
      
        '
      
      
        2012-03-10
      
      
        '
      
      ,
      
        '
      
      
        2012-03-11
      
      
        '
      
      ,
      
        '
      
      
        2012-03-11
      
      
        '
      
      );
    

測試結果:

SQL 判斷兩個時間段是否有交叉

?

?

?

SQL 判斷兩個時間段是否有交叉


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 国产精品分类视频分类一区 | 欧美特黄级乱色毛片 | 色婷婷免费视频 | 日本特黄a级高清免费大片18 | 色噜噜狠狠色综合免费视频 | 亚洲成人aaa | 欧美一级xxxxⅹ毛片 | 男女啪啪网站 | 久久99亚洲精品久久99 | 婷婷涩涩 | 国产精品成在线观看 | 国产观看精品一区二区三区 | 成人a免费α片在线视频网站 | 激情五月综合网 | 夜夜摸夜夜操 | 精精国产www视频在线观看免费 | a一级毛片视频免费看 | 亚洲国产精品久久久天堂麻豆 | 国产在线精彩视频 | 国产婷婷色综合成人精品 | 黄wwwwww| 日本一区高清 | 亚洲一区二区三区久久精品 | 日韩欧美国产综合 | 成熟热自由日本语亚洲人 | 九九色综合 | 亚洲高清免费在线观看 | 久久草在线播放 | 毛片成人永久免费视频 | 免费观看日本污污ww网站精选 | 亚洲欧洲精品国产区 | 国产欧美乱码在线看 | 爱做久久久久久久久久 | 91久久亚洲精品一区二区 | 777奇米影视视频在线播放 | www.精东| 久久久精品免费视频 | 亚洲综合欧美在线 | 久久国产视屏 | 五月婷婷社区 | 国产欧美精品一区二区三区四区 |