日期函数问题

finsoft_001 2008-04-09 10:04:19
DECLARE @BeginDate Datetime
DECLARE @EndDate datetime

我知道 @BeginDate 的值是 2008-4-9
怎么才能将@BeginDate的值变成 2008-4-9 00:00:00
和我知道 @EndDate 的值是 2008-4-10
怎么才能将@EndDate 的值变成 2008-4-10 23:59:59


...全文
55 点赞 收藏 8
写回复
8 条回复
切换为时间正序
当前发帖距今超过3年,不再开放新的回复
发表回复
kakajya 2008-04-09
数据类型设置成datetime类型
它默认的格式就是2008-4-9 00:00:00 这种样子的
所以要达到你说的要求
只需要:>=(2008-4-9这个时间) and <(2008-4-11这个时间)就可以了吧.
回复
补课 2008-04-09
同意楼一的说法.

@BeginDate='2008-04-09' ---些时已经默认是 2008-04-09 00:00:00

如果真的要用增减时间的话可以用 dateadd 函数对时间进行增减
addteadd(second,-1,addteadd(day,1,@EndDate))
回复
Limpire 2008-04-09
DECLARE @BeginDate Datetime
DECLARE @EndDate datetime
set @BeginDate = '2008-4-9'
set @EndDate = '2008-4-10'

select @BeginDate --> 2008-04-09 00:00:00.000
select dateadd(second, -2, @EndDate + 1) -->2008-04-10 23:59:59.000
--> 有一个问题,就是导致毫秒级的丢失
select * from 表 where BeginDate >= @BeginDate and EndDate <= dateadd(second, -1, @EndDate + 1)

--> 还不如1楼所言,来得精确:
select * from 表 where BeginDate >= @BeginDate and EndDate < @EndDate + 1
回复
-狙击手- 2008-04-09
dateadd(ss,-1,dateadd(dd,1,@enddate))  -- '2008-4-10 23:59:59'
回复
cxmcxm 2008-04-09
@begindate 赋值时00:00:00会自动加上

@enddate 赋值中 ,加1天再减1秒即可 用dateadd函数实现
dateadd(ss,dateadd(dd,@enddate,1),-1)
回复
tim_spac 2008-04-09
 DECLARE @BeginDate Datetime
DECLARE @EndDate datetime

set @BeginDate = '2008-4-9'

if @BeginDate='2008-4-9 00:00:00'
print 'OK' -- this will show

set @EndDate = '2008-4-10'
if dateadd(ms,-3, dateadd(day, 1, @endDate) ) = '2008-4-10 23:59:59'
print 'is it?' -- this will not show
else if dateadd(second,-1, dateadd(day, 1, @endDate) ) = '2008-4-10 23:59:59'
print 'O<' -- this will show
回复
fcuandy 2008-04-09
如果你是想按这两个变量进行筛选,那么确实,如楼上所说.

如果想转成那个格式.

@beginDate 为 2008-4-9 ,这是你以字串方式赋进去的,它为datetime类型,也就是一经给他赋值,它已经变成了 2008-4-9 00:00:00.000 了,所以不要处理.

@endDate 要减一秒的话,那么

SET @endDate=DATEADD(s,-1,@endDate) 即可.
回复
jinjazz 2008-04-09
其是你没必要这么做, 只要用>=@BeginDate and <@EndDate就不用和时间纠缠了,只需要管日期
回复
相关推荐
发帖
MS-SQL Server
创建于2007-09-28

3.3w+

社区成员

MS-SQL Server相关内容讨论专区
申请成为版主
帖子事件
创建了帖子
2008-04-09 10:04
社区公告
暂无公告