当前位置:七道奇文章资讯数据防范MSSQL防范
日期:2012-03-30 10:24:00  来源:本站整理

SQL关于DATEDIFF介绍及同日差别月差别年的问题解析[MSSQL防范]

赞助商链接



  本文“SQL关于DATEDIFF介绍及同日差别月差别年的问题解析[MSSQL防范]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:

  目前需求做一个数据库数据的简单统计,包含每日,昨日,每周,每月,每年的数据解析

  利用的是

  SQL Server DATEDIFF() 函数

  先介绍一下基本语法:

  定义和用法

  DATEDIFF() 函数返回两个日期之间的天数.

  语法

  DATEDIFF(datepart,startdate,enddate)

  startdate 和 enddate 参数是合理的日期表达式.

  datepart 参数可以是下列的值:

  datepart 缩写

  年 yy, yyyy

  季度 qq, q

  月 mm, m

  年中的日 dy, y

  日 dd, d

  周 wk, ww

  星期 dw, w

  小时 hh

  分钟 mi, n

  秒 ss, s

  毫秒 ms

  奇妙 mcs

  纳秒 ns

  实例

  例子 1

  利用以下 SELECT 语句:

  SELECT DATEDIFF(day,'2008-12-29','2008-12-30') AS DiffDate

  后果:

  DiffDate

  1

  例子 2

  利用以下 SELECT 语句:

  SELECT DATEDIFF(day,'2008-12-30','2008-12-29') AS DiffDate

  后果:DiffDate -1

  在数据库中的具体利用如:

  select * from 【表名】fyxh_usercommand where 【条件】 and datediff(d,【列名】,getdate())=0

  最后的0代表差值为0

  问题描写:

  在利用的历程中我利用的是

  select * from 【表名】fyxh_usercommand where 【条件】 and datediff(d,day(【列名】),day(getdate()))=0

  发现当前时间假定是2012-02-23 16:12:12.000

  列的时间包含2012-02-23 16:12:12.000 和 2012-01-23 16:12:12.000

  后果日差值为0的条件是两条城市显示

  但是利用

  select * from 【表名】fyxh_usercommand where 【条件】 and datediff(d,【列名】,getdate())=0

  显示的是正常的差值,没有错误

  最后解析了一下

  查询 select day('2012-01-20 16:12:12.000') 后果20

  查询 select '2012-01-20 16:12:12.000' 后果2012-01-20 16:12:12.000

  才想到day('*********') 的意思是只取时间中的天

  这样解析出来就懂得了 上面出错的问题了:利用day('')函数得到的天于天之间的对比

  作者 风云轩海


  以上是“SQL关于DATEDIFF介绍及同日差别月差别年的问题解析[MSSQL防范]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
  • SQL关于DATEDIFF介绍及同日差别月差别年的问题解析
  • 本文地址: 与您的QQ/BBS好友分享!
    • 好的评价 如果您觉得此文章好,就请您
        0%(0)
    • 差的评价 如果您觉得此文章差,就请您
        0%(0)

    文章评论评论内容只代表网友观点,与本站立场无关!

       评论摘要(共 0 条,得分 0 分,平均 0 分) 查看完整评论
    Copyright © 2020-2022 www.xiamiku.com. All Rights Reserved .