--Createdat" />

日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

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

系統 2380 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條評論
主站蜘蛛池模板: 阿克苏市| 峨眉山市| 乐陵市| 江山市| 漠河县| 四平市| 京山县| 比如县| 岳普湖县| 富源县| 宝丰县| 巨鹿县| 南岸区| 北安市| 化隆| 蒙阴县| 陆良县| 措美县| 安顺市| 澜沧| 农安县| 衡山县| 西昌市| 陇川县| 鹿泉市| 卢龙县| 泽普县| 南郑县| 贡嘎县| 万年县| 宝应县| 大厂| 商洛市| 连城县| 保德县| 若尔盖县| 衡阳市| 鄯善县| 藁城市| 九江市| 重庆市|