SQL中的cast 函式

2021-09-07 15:00:28 字數 1971 閱讀 3265

cast函式用於將某種資料型別的表示式顯式轉換為另一種資料型別。cast()函式的引數是乙個表示式,它包括用as關鍵字分隔的源值和目標資料型別。

一、語法:

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

例項:

select * from vrv_paw_genuinemanagementstatic where softid=8 order by cast(version as decimal(9,2)) desc limit 0,1

總結:

cast()主要用於型別轉換;在sql中轉換用於比較大小排序比較多;對於小數,注意使用cast(n as decimal(9,2))。

sql中的cast函式

一 語法 cast expression as data type 引數說明 expression 任何有效的sqserver表示式。as 用於分隔兩個引數,在as之前的是要處理的資料,在as之後是要轉換的資料型別。data type 目標系統所提供的資料型別,包括bigint和sql varian...

SQL中的cast 函式

一 語法 cast expression as data type 引數說明 expression 任何有效的sqserver表示式。as 用於分隔兩個引數,在as之前的是要處理的資料,在as之後是要轉換的資料型別。data type 目標系統所提供的資料型別,包括bigint和sql varian...

SQL中的cast 函式

更多2013 9 11 瀏覽量 229424 學習標籤 sqlcast 一 語法 cast expression as data type 引數說明 expression 任何有效的sqserver表示式。as 用於分隔兩個引數,在as之前的是要處理的資料,在as之後是要轉換的資料型別。data t...