SQL中的cast函數(shù)——數(shù)據(jù)轉(zhuǎn)換

2018-07-07 18:47 更新

本文導(dǎo)讀:CAST函數(shù)用于將某種數(shù)據(jù)類型的表達(dá)式顯式轉(zhuǎn)換為另一種數(shù)據(jù)類型。CAST()函數(shù)的參數(shù)是一個(gè)表達(dá)式,它包括用AS關(guān)鍵字分隔的源值和目標(biāo)數(shù)據(jù)類型。

一、語法:

CAST (expression AS data_type)

參數(shù)說明:

expression:任何有效的SQServer表達(dá)式。

AS:用于分隔兩個(gè)參數(shù),在AS之前的是要處理的數(shù)據(jù),在AS之后是要轉(zhuǎn)換的數(shù)據(jù)類型。

data_type:目標(biāo)系統(tǒng)所提供的數(shù)據(jù)類型,包括bigint和sql_variant,不能使用用戶定義的數(shù)據(jù)類型。

使用CAST函數(shù)進(jìn)行數(shù)據(jù)類型轉(zhuǎn)換時(shí),在下列情況下能夠被接受:

(1)兩個(gè)表達(dá)式的數(shù)據(jù)類型完全相同。 (2)兩個(gè)表達(dá)式可隱性轉(zhuǎn)換。 (3)必須顯式轉(zhuǎn)換數(shù)據(jù)類型。

如果試圖進(jìn)行不可能的轉(zhuǎn)換(例如,將含有字母的 char 表達(dá)式轉(zhuǎn)換為 int 類型),SQServer 將顯示一條錯(cuò)誤信息。 如果轉(zhuǎn)換時(shí)沒有指定數(shù)據(jù)類型的長度,則SQServer自動(dòng)提供長度為30。

二、注意事項(xiàng):

(1).CAST()函數(shù)的參數(shù)是一個(gè)表達(dá)式,它包括用AS關(guān)鍵字分隔的源值和目標(biāo)數(shù)據(jù)類型。以下例子用于將文本字符串'12'轉(zhuǎn)換為整型:

SELECT CAST('12' AS int)

(2).返回值是整型值12。如果試圖將一個(gè)代表小數(shù)的字符串轉(zhuǎn)換為整型值,又會(huì)出現(xiàn)什么情況呢?

SELECT CAST('12.5' AS int)

(3).CAST()函數(shù)和CONVERT()函數(shù)都不能執(zhí)行四舍五入或截?cái)嗖僮?。由?2.5不能用int數(shù)據(jù)類型來表示,所以對這個(gè)函數(shù)調(diào)用將產(chǎn)生一個(gè)錯(cuò)誤:

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).要返回一個(gè)合法的數(shù)值,就必須使用能處理這個(gè)值的數(shù)據(jù)類型。對于這個(gè)例子,存在多個(gè)可用的數(shù)據(jù)類型。如果通過CAST()函數(shù)將這個(gè)值轉(zhuǎn)換為decimal類型,需要首先定義decimal值的精度與小數(shù)位數(shù)。在本例中,精度與小數(shù)位數(shù)分別為9 與2。精度是總的數(shù)字位數(shù),包括小數(shù)點(diǎn)左邊和右邊位數(shù)的總和。而小數(shù)位數(shù)是小數(shù)點(diǎn)右邊的位數(shù)。這表示本例能夠支持的最大的整數(shù)值是9999999,而最小的小數(shù)是0.01。

SELECT CAST('12.5' AS decimal(9,2))

decimal數(shù)據(jù)類型在結(jié)果網(wǎng)格中將顯示有效小數(shù)位: 12.50

(5).精度和小數(shù)位數(shù)的默認(rèn)值分別是18與0。如果在decimal類型中不提供這兩個(gè)值,SQL Server將截?cái)鄶?shù)字的小數(shù)部分,而不會(huì)產(chǎn)生錯(cuò)誤。

SELECT CAST('12.5' AS decimal)

結(jié)果是一個(gè)整數(shù)值:12

以上內(nèi)容是否對您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號(hào)
微信公眾號(hào)

編程獅公眾號(hào)