Chuyển dữ liệu dạng text (Char or nvarchar) sang datetime

Bạn muốn chuyển đổi dữ liệu từ text (Char or nvarchar) sang datetime. Bạn có thể xem hàm sau đây. Tôi viết hàm chuyển dạng text (dd/MM/yyyy) còn các định dạng khác bạn có thể Alter hàm để dùng cho đúng mục đích.

 

--Input: char/varchar
--Output: datetime

CREATE FUNCTION dbo.ChuyenTextSangDateTime
(@mNgay nvarchar(10))  
RETURNS datetime
AS  

BEGIN 
    DECLARE @mDate   datetime
    if (len(@mNgay)>=8)--đủ ngày tháng năm
    Set @mDate=  cast(substring(@mNgay,
    CHARINDEX('/',@mNgay,0)+1,
    CHARINDEX('/',@mNgay, CHARINDEX('/',@mNgay,0)+1)
    -CHARINDEX('/',@mNgay,0)-1 )+'/'+
    substring( @mNgay,0,CHARINDEX('/',@mNgay,0))+'/'+
    substring(@mNgay, 
    CHARINDEX('/',@mNgay,CHARINDEX('/',@mNgay,0)+1)+1 , 
    len(@mNgay)-CHARINDEX('/',@mNgay,CHARINDEX('/',@mNgay,0)+1))
    as datetime)
    else
    if (len(@mNgay)>4 AND len(@mNgay)<8)--có tháng năm
    Set @mDate=cast(substring(@mNgay,0,CHARINDEX('/',@mNgay,0))+'/01/'+
        substring(@mNgay, CHARINDEX('/',@mNgay,0)+1, 
        len(@mNgay)-CHARINDEX('/',@mNgay,0))
               as datetime)
    else-- có năm
        Set @mDate= cast( '01/01/'+ @mNgay  as datetime)

    return @mDate
END

Bạn có thể chạy thử hàm trên như sau:

SELECT dbo.ChuyenTextSangDateTime ('22/08/2009')

Chúc các bạn thành công!