1. 程式人生 > >SQL中的CAST()函式

SQL中的CAST()函式

一、語法:

CAST (expression AS data_type)引數說明:expression:任何有效的SQServer表示式。AS:用於分隔兩個引數,在AS之前的是要處理的資料,在AS之後是要轉換的資料型別。data_type:目標系統所提供的資料型別,包括bigint和sql_variant,不能使用使用者定義的資料型別。

使用CAST函式進行資料型別轉換時,在下列情況下能夠被接受: (1)兩個表示式的資料型別完全相同。 (2)兩個表示式可隱性轉換。 (3)必須顯式轉換資料型別。如果試圖進行不可能的轉換(例如,將含有字母的 char 表示式轉換為 int 型別),SQServer 將顯示一條錯誤資訊。

如果轉換時沒有指定資料型別的長度,則SQServer自動提供長度為30。

二、注意事項

注意事項:
 
(1).CAST()函式的引數是一個表示式,它包括用AS關鍵字分隔的源值和目標資料型別。以下例子用於將文字字串'12'轉換為整型:
 
SELECT CAST('12' AS int)
 
(2).返回值是整型值12。如果試圖將一個代表小數的字串轉換為整型值,又會出現什麼情況呢?
 
SELECT CAST('12.5' AS int)
 
(3).CAST()函式和CONVERT()函式都不能執行四捨五入或截斷操作。由於12.5不能用int資料型別來表示,所以對這個函式呼叫將產生一個錯誤:
 
Server: Msg 245, Level 16, State 1, Line 1
 
Syntax error converting the varchar value
 
    '12.5' to a column of data type int.
 
(4).要返回一個合法的數值,就必須使用能處理這個值的資料型別。對於這個例子,存在多個可用的資料型別。如果通過CAST()函式將這個值轉換為decimal型別,需要首先定義decimal值的精度與小數位數。在本例中,精度與小數位數分別為9 與2。精度是總的數字位數,包括小數點左邊和右邊位數的總和。而小數位數是小數點右邊的位數。這表示本例能夠支援的最大的整數值是9999999,而最小的小數是0.01。
 
SELECT CAST('12.5' AS decimal(9,2))
 
decimal資料型別在結果網格中將顯示有效小數位: 12.50
 
(5).精度和小數位數的預設值分別是18與0。如果在decimal型別中不提供這兩個值,SQL Server將截斷數字的小數部分,而不會產生錯誤。
 
SELECT CAST('12.5' AS decimal)
 
    結果是一個整數值:12