日期函数问题

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


...全文
83 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
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就不用和时间纠缠了,只需要管日期

34,588

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧