• SQL server 2005 时间函数应用 查询出结果为00:00:00 小时、分钟、秒


    C# winform

    时间差 计算
    使用TimeSpan ,同时也介绍一下TimeSpan的用法
    相关属性和函数
    Add:与另一个TimeSpan值相加。
    Days:返回用天数计算的TimeSpan值。
    Duration:获取TimeSpan的绝对值。
    Hours:返回用小时计算的TimeSpan值
    Milliseconds:返回用毫秒计算的TimeSpan值。
    Minutes:返回用分钟计算的TimeSpan值。
    Negate:返回当前实例的相反数。
    Seconds:返回用秒计算的TimeSpan值。
    Subtract:从中减去另一个TimeSpan值。
    Ticks:返回TimeSpan值的tick数。
    TotalDays:返回TimeSpan值表示的天数。
    TotalHours:返回TimeSpan值表示的小时数。
    TotalMilliseconds:返回TimeSpan值表示的毫秒数。
    TotalMinutes:返回TimeSpan值表示的分钟数。
    TotalSeconds:返回TimeSpan值表示的秒数。
    简单示例:
    DateTime d1 =new DateTime(2004,1,1,15,36,05);
    DateTime d2 =new DateTime(2004,3,1,20,16,35);
    TimeSpan d3 = d2.Subtract(d1);
    LbTime.Text = "相差:"
    +d3.Days.ToString()+"天"
    +d3.Hours.ToString()+"小时"
    +d3.Minutes.ToString()+"分钟"
    +d3.Seconds.ToString()+"秒";
    法二、使用Sql中的DATEDIFF函数
    使用方法:DATEDIFF ( datepart , startdate , enddate )
    它能帮你取出你想要的各种形式的时间差,如相隔多少天,多少小时,多少分钟等,具体格式如下:
    日期部分缩写
    year yy, yyyy
    quarter qq, q
    Month mm, m
    dayofyear dy, y
    Day dd, d
    Week wk, ww
    Hour hh
    minute mi, n
    second ss, s
    millisecond ms
    如:datediff(mi,DtOpTime,DtEnd)  便能取出他们之间时间差的分钟总数,已经帮你换算好了,对于要求规定单位,时、分、秒特别有用

    思考:现在有需求需要计算出 DtOpTime与DtEnd的时间差 要求格式为:a时a分a秒

    sql文如下:

    View Code
    select dbo.f_SecondsToHourMinuteSecond(datediff(ss,CoalStartTime,CoalStopTime)) AS Dd
    from KJ201303.dbo.D201303

    自定义函数如下:

    View Code
     1 ------------------------------------------------------          
     2 -- Usage: Convert seconds to Hour:Minute:Second
     3 ------------------------------------------------------          
     4 create  function f_SecondsToHourMinuteSecond(@seconds bigint)          
     5 returns varchar(20)          
     6 as          
     7 begin          
     8   declare @str as varchar(20)  
     9   if @seconds >= 10  --如果秒数大于等于10
    10   begin  
    11     declare @hour as varchar(10)
    12     declare @minute as varchar(10)
    13     declare @second as varchar(10)
    14     if(@seconds/3600 < 10)
    15       begin
    16         set @hour = '0' + convert(varchar(10),@seconds/3600)
    17       end
    18     else
    19       begin
    20         set @hour = convert(varchar(10),@seconds/3600)
    21       end
    22     
    23     if(@seconds%3600/60 < 10)
    24       begin
    25          set @minute = '0' + convert(varchar(10),@seconds%3600/60)
    26       end
    27     else
    28       begin
    29          set @minute = convert(varchar(10),@seconds%3600/60)
    30       end
    31 
    32     if(@seconds%3600%60 < 10)
    33       begin
    34          set @second = '0' + convert(varchar(10),@seconds%3600%60%60)
    35       end
    36     else
    37       begin
    38          set @second = convert(varchar(10),@seconds%3600%60%60)
    39       end
    40     set @str = @hour + ':' + @minute + ':' + @second
    41   end  
    42   else   --如果秒数小于10
    43   begin  
    44      set @str = '00:00:0'+convert(varchar(20),@seconds)  
    45   end  
    46     return(@str)        
    47 end    

  • 相关阅读:
    Atitit 编程语言编程方法的进化演进 sp  COP ,AOP ,SOP
    Atitit 2016年attilax事业成就表
    Atitit 知识管理的重要方法 数据来源,聚合,分类,备份,发布 搜索
    Atitit webservice发现机制 WS-Discovery标准的规范attilax总结
    Atitit 多元化战略 适合我们发展 的核心业务attilax总结
    Atitit HTTP 认证机制基本验证 (Basic Authentication) 和摘要验证 (Digest Authentication)attilax总结
    Atitit. 提升存储过程与编程语言的可读性解决方案v3 qc25.docx
    Atitit zxing二维码qr码识别解析
    Atitit Data Matrix dm码的原理与特点
    Atitit 常用二维码对比(QR、PDF417、DM、汉信码 Aztec code maxicode
  • 原文地址:https://www.cnblogs.com/xiaolong617/p/2945516.html
Copyright © 2020-2023  润新知