免费注册 查看新帖 |

Chinaunix

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

SELECT DATEADD(dd,DATEDIFF(dd,0,@terminal_date),0) [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-08-02 10:21 |只看该作者 |倒序浏览
--DECLARE   @s   datetime   
-- SET   @s   =   getdate()   
SELECT   DATEADD(dd,DATEDIFF(dd,0,@terminal_date),0)

如何把2007-07-20 12:20:50.000
转换为2007-07-20 00:00:00.000

上的语句可以做到这一点
但是不能传给时间变量
set @standard_date= DATEADD(dd,DATEDIFF(dd,0,@terminal_date),0)
她的结果为
2007-07-20 12:20:50.000
不是2007-07-20 00:00:00.000

问如何做到????

论坛徽章:
0
2 [报告]
发表于 2007-08-02 10:35 |只看该作者
在sqlserver中的datetime类型的值都是如下格式的:   
  2006-06-17   12:59:17   
  但没有一个date类型,我只需要日期部分,不需要时间部分,请问怎么办?

论坛徽章:
0
3 [报告]
发表于 2007-08-02 10:38 |只看该作者
declare @etms_p2_data varchar(80)
declare @terminal_date datetime
select @etms_p2_data=convert(char(10),getdate(),120)
print @etms_p2_data
set @terminal_date=@etms_p2_data
print @terminal_date


结果:
2007-08-02
08  2 2007 12:00AM

论坛徽章:
0
4 [报告]
发表于 2007-08-02 10:47 |只看该作者
select cast(convert(char(10),getdate(),120) as datetime)
result:
------------------------------------------------------
2007-08-02 00:00:00.000

(所影响的行数为 1 行)

论坛徽章:
0
5 [报告]
发表于 2007-08-02 10:55 |只看该作者
回复2楼:
select convert(varchar(20),getdate(),111)
go
返回:
--------------------
2007/08/02

(所影响的行数为 1 行)

论坛徽章:
0
6 [报告]
发表于 2007-08-03 14:25 |只看该作者
sqlserver  ----oracle不停的切换
脑袋再好也记不住 不过这次没有问题啦
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP