SQL中CONVERT转化日期函数的使用方法(整理一些高手的贴子)

ljsql  的回复:

SQL中CONVERT转化函数的用法

CONVERT的使用方法:



格式:
CONVERT(data_type,expression[,style])

说明:
此样式一般在时间类型(datetime,smalldatetime)与字符串类型(nchar,nvarchar,char,varchar)
相互转换的时候才用到.

例子:
SELECT   CONVERT(varchar(30),getdate(),102)   now
结果为
now
---------------------------------------
09/15/2001

/

style数字在转换时间时的含义如下

-------------------------------------------------------------------------------------------------
Style(2位表示年份)   |   Style(4位表示年份)   |   输入输出格式  
-------------------------------------------------------------------------------------------------
-   |   0   or   100   |   mon   dd   yyyy   hh:miAM(或PM)  
-------------------------------------------------------------------------------------------------
1   |   101   |   mm/dd/yy  
-------------------------------------------------------------------------------------------------
2   |   102   |   yy-mm-dd  
-------------------------------------------------------------------------------------------------
3   |   103   |   dd/mm/yy  
-------------------------------------------------------------------------------------------------
4   |   104   |   dd-mm-yy  
-------------------------------------------------------------------------------------------------
5   |   105   |   dd-mm-yy  
-------------------------------------------------------------------------------------------------
6   |   106   |   dd   mon   yy  
-------------------------------------------------------------------------------------------------
7   |   107   |   mon   dd,yy  
-------------------------------------------------------------------------------------------------
8   |   108   |   hh:mm:ss  
-------------------------------------------------------------------------------------------------
-   |   9   or   109   |   mon   dd   yyyy   hh:mi:ss:mmmmAM(或PM)
-------------------------------------------------------------------------------------------------
10   |   110   |   mm-dd-yy  
-------------------------------------------------------------------------------------------------
11   |   111   |   yy/mm/dd  
-------------------------------------------------------------------------------------------------
12   |   112   |   yymmdd  
-------------------------------------------------------------------------------------------------
-   |   13   or   113   |   dd   mon   yyyy   hh:mi:ss:mmm(24小时制)  
-------------------------------------------------------------------------------------------------
14   |   114   |   hh:mi:ss:mmm(24小时制)  
-------------------------------------------------------------------------------------------------
-   |   20   or   120   |   yyyy-mm-dd   hh:mi:ss(24小时制)  
-------------------------------------------------------------------------------------------------
-   |   21   or   121   |   yyyy-mm-dd   hh:mi:ss:mmm(24小时制)  
------------------------------------------------------------------------------------------------- 

二、wgsasd311 的回复:

--1.如果mydate是datetime类型字段
select   convert(char(10),myDate,120)   from   myTable
--1.如果mydate是 "字符 "类型字段
select   convert(char(10),cast(myDate   as   datetime),120)   from   myTable

可以将日期格式为20080315 转换为2008-03-15。

三、如果你从EXCEL导入的数据到SQL SERVER 库里,从EXCEL导入的20080315数字到SQL里后,可能这些数字变成了20080315.0000带有小数点的值了,你必须先转换为整型,才能转换为日期型的。如下:

set     abc=20080315.0000

abcd = convert(char(10),cast(abc as int),20)   --这一步相当于把小数点后的4个0000去掉了

convert(char(10),cast(abcd as datetime),20)  --输出日期为:2008-03-15

个人观点
 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值