SQL SERVER中強制類型轉換cast和convert的區別

來源:互聯網
上載者:User

標籤:convert   png   mon   font   select   bsp   技術分享   arc   ast   

在SQL SERVER中,cast和convert函數都可用於類型轉換,其功能是相同的,

只是文法不同.

cast一般更容易使用,convert的優點是可以格式化日期和數值.

 1 select CAST(‘123‘ as int)   -- 123 2 select CONVERT(int, ‘123‘)  -- 123 3  4 select CAST(123.4 as int)   -- 123 5 select CONVERT(int, 123.4)  -- 123  6  7 select CAST(‘123.4‘ as int) 8 select CONVERT(int, ‘123.4‘) 9 -- Conversion failed when converting the varchar value ‘123.4‘ to data type int.10 11 select CAST(‘123.4‘ as decimal)  -- 12312 select CONVERT(decimal, ‘123.4‘) -- 123 13 14 15 select CAST(‘123.4‘ as decimal(9,2))  -- 123.4016 select CONVERT(decimal(9,2), ‘123.4‘) -- 123.4017 18 19 declare @Num money20 set @Num = 1234.5621 select CONVERT(varchar(20), @Num, 0)  -- 1234.5622 select CONVERT(varchar(20), @Num, 1)  -- 1,234.5623 select CONVERT(varchar(20), @Num, 2)  -- 1234.5600

在時間轉化中一般用到convert,因為它比cast多加了一個style,可以轉化成不同時間的格式

CONVERT(data_type(length),data_to_be_converted,style)

data_type(length) 規定目標資料類型(帶有可選的長度)。data_to_be_converted 含有需要轉換的值。style 規定日期/時間的輸出格式。

可以使用的 style 值:

1 CONVERT(VARCHAR(19),GETDATE())2 CONVERT(VARCHAR(10),GETDATE(),110) 3 CONVERT(VARCHAR(11),GETDATE(),106)4 CONVERT(VARCHAR(24),GETDATE(),113)

 

SQL SERVER中強制類型轉換cast和convert的區別

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.