sqlserver中的CAST()函數(shù)
當(dāng)前位置:點晴教程→知識管理交流
→『 技術(shù)文檔交流 』
語法:CAST (expression AS data_type)
參數(shù)說明:
expression:任何有效的SQServer表達式。
AS:用于分隔兩個參數(shù),在AS之前的是要處理的數(shù)據(jù),在AS之后是要轉(zhuǎn)換的數(shù)據(jù)類型。
data_type:目標(biāo)系統(tǒng)所提供的數(shù)據(jù)類型,包括bigint和sql_variant,不能使用用戶定義的數(shù)據(jù)類型。 注意事項:
(1).CAST()函數(shù)的參數(shù)是一個表達式,它包括用AS關(guān)鍵字分隔的源值和目標(biāo)數(shù)據(jù)類型。以下例子用于將文本字符串'12'轉(zhuǎn)換為整型:
select CAST('12' AS int)
(2).返回值是整型值12。如果試圖將一個代表小數(shù)的字符串轉(zhuǎn)換為整型值,又會出現(xiàn)什么情況呢?
select CAST('12.5' AS int)
(3).CAST()函數(shù)和CONVERT()函數(shù)都不能執(zhí)行四舍五入或截斷操作。由于12.5不能用int數(shù)據(jù)類型來表示,所以對這個函數(shù)調(diào)用將產(chǎn)生一個錯誤:
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).要返回一個合法的數(shù)值,就必須使用能處理這個值的數(shù)據(jù)類型。對于這個例子,存在多個可用的數(shù)據(jù)類型。如果通過CAST()函數(shù)將這個值轉(zhuǎn)換為decimal類型,需要首先定義decimal值的精度與小數(shù)位數(shù)。在本例中,精度與小數(shù)位數(shù)分別為9 與2。精度是總的數(shù)字位數(shù),包括小數(shù)點左邊和右邊位數(shù)的總和。而小數(shù)位數(shù)是小數(shù)點右邊的位數(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類型中不提供這兩個值,SQL Server將截斷數(shù)字的小數(shù)部分,而不會產(chǎn)生錯誤。
select CAST('12.5' AS decimal)
結(jié)果是一個整數(shù)值:12 https://blog.csdn.net/qq_27918787/article/details/52593698 該文章在 2023/5/13 10:08:22 編輯過 |
關(guān)鍵字查詢
相關(guān)文章
正在查詢... |