设为首页收藏本站Access中国

Office中国论坛/Access中国论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

返回列表 发新帖
查看: 3195|回复: 0
打印 上一主题 下一主题

[其它] [分享]SQL Server日期格式的转换

[复制链接]
跳转到指定楼层
1#
发表于 2006-3-3 16:11:00 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式


SQL Server中文版的默认的日期字段datetime格式是yyyy-mm-dd Thh:mm:ss.mmm

例如:

select getdate()

2004-09-12 11:06:08.177

这对于在要不同数据库间转移数据或者习惯oracle日期格式YYYY-MM-DD HH24:MI:SS的人多少有些不方便.

整理了一下SQL Server里面可能经常会用到的日期格式转换方法:

举例如下:

select CONVERT(varchar, getdate(), 120 )
2004-09-12 11:06:08

select replace(replace(replace(CONVERT(varchar, getdate(), 120 ),'-',''),' ',''),':','')
20040912110608

select CONVERT(varchar(12) , getdate(), 111 )
2004/09/12

select CONVERT(varchar(12) , getdate(), 112 )
20040912

select CONVERT(varchar(12) , getdate(), 102 )
2004.09.12

其它我不常用的日期格式转换方法:

select CONVERT(varchar(12) , getdate(), 101 )
09/12/2004

select CONVERT(varchar(12) , getdate(), 103 )
12/09/2004

select CONVERT(varchar(12) , getdate(), 104 )
12.09.2004

select CONVERT(varchar(12) , getdate(), 105 )
12-09-2004

select CONVERT(varchar(12) , getdate(), 106 )
12 09 2004

select CONVERT(varchar(12) , getdate(), 107 )
09 12, 2004

select CONVERT(varchar(12) , getdate(), 108 )
11:06:08

select CONVERT(varchar(12) , getdate(), 109 )
09 12 2004 1

select CONVERT(varchar(12) , getdate(), 110 )
09-12-2004

select CONVERT(varchar(12) , getdate(), 113 )
12 09 2004 1

select CONVERT(varchar(12) , getdate(), 114 )
11:06:08.177

更多的及具体说明请参考SQL Server的联机丛书.



默认系统日期:GETDATE()
  在创建表或者插入/修改表记录的时候可以用作默认值
 转换日期函数:
  默认的GETDATE函数只显示到秒,实际上SQLServer内部时间可以精确到毫秒级(3.33毫秒),
  使用CONVERT函数转换一下即可显示,比如:
  select CONVERT(VRRCHAR(30),GETDATE(),9)
  下表显示了SQL Server中的所有日期格式

 抽取日期函数:DATEPART() DATENAME()
  select column1,DATEPART(mm,datecolumn) datepartcolumn from tablename
  显示出来datepartcolumn就是日期中的月份
  下表是DATEPART中参数的使用方法


  还可以使用DATENAME()返回部分日期的文字表示
  select column1,DATENAME(mm,datecolumn) datepartcolumn from tablename
  这样显示的就不是数字,而是月份所对应的单词了

 取时间段方法
  因为数据库在保存日期的时候不是仅仅保存了日期,还有时间信息,所以不能直接用下面的方法去数据
  select * from table where column='2005-02-06'
  这样写的话实际上只能取出2005-02-06 00:00:00那个时刻的数据
  可以参考以下两种写法:
  select * from tablename where column>='2005-02-06' and column<='2005-02-07'
  select * from tablename where column like '2005-02-06%'

 比较日期和时间:DATEDIFF() DATEADD()
  select * from tablename where DATEDIFF(dd,datecolumn,GETDATE())>3
  上面的语句可以检索出datecolumn是三天以前的记录
  DATEADD()是把两个日期相加,在计算截止日期的时候很有用处
  select DATEADD(mm,1,datecolumn) as lastdate from tablename
  出来的结果就是datecolumn的日期再加上一个月,这样就能算出什么时候是最终日期
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏1 分享分享 分享淘帖 订阅订阅
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|站长邮箱|小黑屋|手机版|Office中国/Access中国 ( 粤ICP备10043721号-1 )  

GMT+8, 2024-4-30 14:40 , Processed in 0.095397 second(s), 24 queries .

Powered by Discuz! X3.3

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表