SQL关于DATEDIFF介绍及同日不同月不同年的问题分析

来源:未知 责任编辑:责任编辑 发表时间:2014-01-26 22:00 点击:

目前需要做一个数据库数据的简单统计,包括每日,昨日,每周,每月,每年的数据分析
使用的是
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常见面试题
  • SQL SERVER 2005性能之跟踪
  • SQL编程(一)
  • LINUX上RMAN自动备份脚本
  • sql server面试题
  • 如何将多个SQL查询统计结果一次显示出来
  • 浅谈SQL Server中的事务日志(三)----在简单恢复模式下日志的角色
  • sql server 列转行
  • SQL小技巧系列 --- 行转列合并
网站首页 - 友情链接 - 网站地图 - TAG标签 - RSS订阅 - 内容搜索
Copyright © 2008-2015 计算机技术学习交流网. 版权所有

豫ICP备11007008号-1