欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

關(guān)于SQL的cast()函數(shù)解析

 更新時間:2023年04月28日 09:24:48   作者:陳老老老板  
這篇文章主要介紹了關(guān)于SQL的cast()函數(shù)解析,CAST函數(shù)用于將某種數(shù)據(jù)類型的表達式顯式轉(zhuǎn)換為另一種數(shù)據(jù)類型。CAST()函數(shù)的參數(shù)是一個表達式,它包括用AS關(guān)鍵字分隔的源值和目標數(shù)據(jù)類型,需要的朋友可以參考下

注意:本文使用數(shù)據(jù)庫為:MySQL5.6

解析: CAST函數(shù)用于將某種數(shù)據(jù)類型的表達式顯式轉(zhuǎn)換為另一種數(shù)據(jù)類型。

CAST()函數(shù)的參數(shù)是一個表達式,它包括用AS關(guān)鍵字分隔的源值和目標數(shù)據(jù)類型。

語法:

CAST (expression AS data_type)
參數(shù)說明
expression任何有效的SQServer表達式。
AS用于分隔兩個參數(shù),在AS之前的是要處理的數(shù)據(jù),在AS之后是要轉(zhuǎn)換的數(shù)據(jù)類型。
data_type目標系統(tǒng)所提供的數(shù)據(jù)類型,包括bigint和sql_variant,不能使用用戶定義的數(shù)據(jù)類型。
限制:

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

(1)兩個表達式的數(shù)據(jù)類型完全相同。   

(2)兩個表達式可隱性轉(zhuǎn)換。   

(3)必須顯式轉(zhuǎn)換數(shù)據(jù)類型。

如果試圖進行不可能的轉(zhuǎn)換(例如,將含有字母的 char 表達式轉(zhuǎn)換為 int 類型),SQServer 將顯示一條錯誤信息。

注意: 如果試圖將一個代表小數(shù)的字符串轉(zhuǎn)換為整型值,又會出現(xiàn)什么情況呢?

SELECT CAST('12.5' AS int)

CAST()函數(shù)和CONVERT()函數(shù)都不能執(zhí)行四舍五入或截斷操作。由于12.5不能用int數(shù)據(jù)類型來表示,所以對這個函數(shù)調(diào)用將產(chǎn)生一個錯誤:

在這里插入圖片描述

解決: 要返回一個合法的數(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))

在這里插入圖片描述

精度和小數(shù)位數(shù)的默認值分別是18與0。如果在decimal類型中不提供這兩個值,SQL Server將截斷數(shù)字的小數(shù)部分,而不會產(chǎn)生錯誤。

SELECT CAST('12.5' AS decimal)
結(jié)果為 13

注意:在這個數(shù)據(jù)庫版本會四舍五入,在其他版本可能不同,但用法相同

在這里插入圖片描述

類型:

如果轉(zhuǎn)換時沒有指定數(shù)據(jù)類型的長度,則SQServer自動提供長度為30。
二進制,同帶binary前綴的效果 : BINARY
字符型,可帶參數(shù) : CHAR()
日期 : DATE
時間: TIME
日期時間型 : DATETIME
浮點數(shù) : DECIMAL
整數(shù) : SIGNED
無符號整數(shù) : UNSIGNED

例子:

1.SELECT CAST('9.0' AS decimal) 結(jié)果:9

在這里插入圖片描述

2.SELECT CAST('9.5' AS decimal(10,2))

結(jié)果:9.50 注:(精度與小數(shù)位數(shù)分別為10與2。精度是總的數(shù)字位數(shù),包括小數(shù)點左邊和右邊位數(shù)的總和。而小數(shù)位數(shù)是小數(shù)點右邊的位數(shù))

在這里插入圖片描述

3.SELECT CAST(NOW() AS DATE)

結(jié)果:2017-11-27

在這里插入圖片描述

到此這篇關(guān)于關(guān)于SQL的cast()函數(shù)解析的文章就介紹到這了,更多相關(guān)SQL的cast()函數(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評論