--Createdat" />

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

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

系統 2414 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大片黑 | 国产精品深夜福利免费观看 | 精品久久久久久无码中文字幕 | 亚洲日本香蕉视频 | 日本一区二区三区四区在线观看 | 国产精品免费大片一区二区 | 色综合亚洲七七久久桃花影院 | 最新亚洲精品国自产在线观看 | 一区二区三区中文字幕 | 国产精品久久久久久久久久98 | 亚洲图片欧美日韩 | 国产在线视频一区 | 国产欧美成人免费观看视频 | 亚洲精品久久99久久一区 | 国产欧美一区二区三区久久 | 亚洲欧美日韩精品一区 | 91糖心 | 欧美色xxx | 伊人一区 | 久久久男女野外野战 | 亚洲欧美日韩v中文在线 | 毛片免费视频 | 亚洲欧美成人在线 | 天天搞天天搞 | 91精品国产免费网站 | 免费h片网站 | 国产视频二 | 97se综合| 四虎久久影院 | 国产91在线精品 | 国产日韩欧美综合一区 | 狠狠干夜夜骑 | 成人精品国产 | 日韩一级特黄毛片在线看 | 亚洲 欧美 日韩在线综合福利 | 欧美高清视频www夜色资源 | 欧美整片在线观看 | 亚洲精品高清视频 | 天天做天天爱夜夜爽毛片毛片 | 欧洲精品视频在线观看 |