程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> 關於MYSQL數據庫 >> sql日期時間相減語句

sql日期時間相減語句

編輯:關於MYSQL數據庫

       sql日期時間相減語句

      本款教程利用了datediff函數,來對數據庫教程的日期進行相減查詢哦,下面便寫了n種關於mssql 日期相減的方法。

      sql中兩個日期相減

      1、相差天數

      select trunc(sysdate,'yyyy')-to_date('2009-01-04','yyyy-mm-dd') from dual;

      2、相差月數

      select months_between(trunc(sysdate,'mm'),to_date('2009-01','yyyy-mm')) from dual;

      3、相差年數

      select trunc((months_between(trunc(sysdate,'dd'),to_date('2009-01-01','yyyy-mm-dd')))/12) from dual;

      4、select datediff( day, '2008.08.25', '2008.09.01' )

      5、select datediff( second, 2009-8-25 12:15:12', 2009-9-1 7:18:20') --返回相差秒數

      6、

      select datediff( minute, 2009-8-25 12:15:12', 2009-9-1 7:18:20') --返回相差分鐘數

      7、

      select datediff( hour, 2009-8-25 12:15:12', 2009-9-1 7:18:20') --返回相差小時數

      問題三:select datediff( day, 2009-8-25 12:15:12', 2009-9-1 7:18:20')

      實例二

      use pubs

      select distinct datediff(day, '2009-3-12', '2009-3-15') as difday

      from titles

      結果:3

      declare @dt1 as datetime, @dt2 as datetime;

      select @dt1 = '2008-8-4 9:36:41', @dt2 = '2008-8-2 9:33:39';

      declare @days as int, @hours as int, @minutes as int, @seconds as int;

      set @seconds = datediff( second, @dt2, @dt1);

      set @days = @seconds / (24 * 60 * 60)

      set @seconds = @seconds - @days * 24 * 60 * 60

      set @hours = @seconds / (60 * 60);

      set @seconds = @seconds - @hours * 60 * 60

      set @minutes = @seconds / 60;

      set @seconds = @seconds - @minutes * 60;

      select convert(varchar(10), @days ) + '天' + convert(varchar(10), @hours ) + '小時' + convert(varchar(10), @minutes ) + '分' + convert(varchar(10), @seconds ) + '秒';

      下面來看個實例

      我有一個表,其中有四個字段:開始天數,開始時間,到達天數,到達時間(這四個字段都是varchar類型)

      例如:某一條記錄: 1 16:00 2 12:20

      我的目的就是用 select(到達天數+到達時間)-(開始天數+開始時間) as 花費時間 from table

      例如上條記錄得到的就是 (2*24:00+12:20)-(24:00+16:00)=20:00

      這樣的sql語句該怎麼寫???

      declare @t table

      (

      beginday int,

      begintime varchar(20),

      endday int,

      endtime varchar(20)

      )

      insert @t select 1,'16:00',2,'12:20'

      union all select 1,'3:00',3,'19:10'

      select

      date=rtrim(date/60)+':'+rtrim(date%60)

      from

      (select date=datediff(mi,1,dateadd(d,endday-beginday,beginday)-begintime+endtime)from @t )t

      date

      -------------------------

      20:20

      64:10

      方法二

      declare @t table(開始天數 varchar(10),開始時間 varchar(10),到達天數 varchar(10),到達時間 varchar(10))

      insert @t select '1', '16:00','2','12:20'

      --如果開始天數,到達天數大於31

      select 到達天數 * 24 + datepart(hh,到達時間) - 開始天數 * 24 - datepart(hh,開始時間)

      from @t

    1. 上一頁:
    2. 下一頁:
    Copyright © 程式師世界 All Rights Reserved