免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 4005 | 回复: 2
打印 上一主题 下一主题

datediff问题。。 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2003-01-12 20:52 |只看该作者 |倒序浏览
select datediff(yy,\'20001001\',\'20020801\');

这个结果怎么会是2的????没有二年啊。。

select fname,lname,hire_date from employee
where datediff(yyyy,hire_date,(getdate()+30)) >datediff(yyyy,hire_date,getdate())

用这个函数想返回:接下来的30天中工作n周年的公司雇员。。怎么样返回啊??谢谢

一本书是抄的,但试的时候总是不成功。。
库就是sqlserver中自带的pub库,谢谢。。。

论坛徽章:
0
2 [报告]
发表于 2003-01-13 17:16 |只看该作者
1,  datediff 参数第一个是类型,你选择的是年,比较的时候会忽略年后的数据,只比较年
所以2002-2000=2。如果需要真正的2年,可以考虑从天出发。达到XXX天是2年。如还不准确可以选择小时、分钟、秒,这些可以通过查看datediff用法得到。
2,
try follows:

declare @day int, @year int--接下来的@day天, @year周年, >=号可以根据周年的定义替换为>
select @day = 30, @year = 14
select fname,lname,hire_date from employee
where datediff(d, hire_date, dateadd(d, @day, getdate())) >= datediff(d, dateadd(yyyy, -@year, getdate()), getdate())
order by hire_date


yours,
Jefferson Han

论坛徽章:
0
3 [报告]
发表于 2003-01-14 12:42 |只看该作者
谢谢,我先试试先。。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP