關(guān)于SQL的cast()函數(shù)解析
注意:本文使用數(shù)據(jù)庫為:MySQL5.6
解析: 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ò)誤信息。
注意: 如果試圖將一個(gè)代表小數(shù)的字符串轉(zhuǎn)換為整型值,又會(huì)出現(xiàn)什么情況呢?
SELECT CAST('12.5' AS int)
CAST()函數(shù)和CONVERT()函數(shù)都不能執(zhí)行四舍五入或截?cái)嗖僮?。由?2.5不能用int數(shù)據(jù)類型來表示,所以對(duì)這個(gè)函數(shù)調(diào)用將產(chǎn)生一個(gè)錯(cuò)誤:
解決: 要返回一個(gè)合法的數(shù)值,就必須使用能處理這個(gè)值的數(shù)據(jù)類型。對(duì)于這個(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))
精度和小數(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é)果為 13
注意:在這個(gè)數(shù)據(jù)庫版本會(huì)四舍五入,在其他版本可能不同,但用法相同
類型:
如果轉(zhuǎn)換時(shí)沒有指定數(shù)據(jù)類型的長度,則SQServer自動(dòng)提供長度為30。
二進(jìn)制,同帶binary前綴的效果 : BINARY
字符型,可帶參數(shù) : CHAR()
日期 : DATE
時(shí)間: TIME
日期時(shí)間型 : DATETIME
浮點(diǎn)數(shù) : DECIMAL
整數(shù) : SIGNED
無符號(hào)整數(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ù)點(diǎn)左邊和右邊位數(shù)的總和。而小數(shù)位數(shù)是小數(shù)點(diǎn)右邊的位數(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)文章
mysql/Java服務(wù)端對(duì)emoji的支持與問題解決方法詳解
這篇文章主要介紹了mysql/Java服務(wù)端對(duì)emoji的支持與問題解決方法,結(jié)合實(shí)例形式分析了mysql/Java服務(wù)端對(duì)emoji字符集存儲(chǔ)及支持問題解決方法,需要的朋友可以參考下2019-10-10Mysql數(shù)據(jù)庫從5.6.28版本升到8.0.11版本部署項(xiàng)目時(shí)遇到的問題及解決方法
這篇文章主要介紹了Mysql數(shù)據(jù)庫從5.6.28版本升到8.0.11版本過程中遇到的問題及解決方法,解決辦法有三種,每種方法給大家介紹的都很詳細(xì),感興趣的朋友跟隨腳本之家小編一起學(xué)習(xí)吧2018-05-05計(jì)算機(jī)二級(jí)考試MySQL知識(shí)點(diǎn) mysql alter命令
這篇文章主要為大家詳細(xì)介紹了計(jì)算機(jī)二級(jí)考試MySQL知識(shí)點(diǎn),詳細(xì)介紹了mysql中alter命令的使用方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-08-08MYSQL必知必會(huì)讀書筆記第十和十一章之使用函數(shù)處理數(shù)據(jù)
這篇文章主要介紹了MYSQL必知必會(huì)讀書筆記第十和十一章之使用函數(shù)處理數(shù)據(jù)的相關(guān)資料,需要的朋友可以參考下2016-05-05MySQL數(shù)據(jù)存儲(chǔ)路徑修改的超詳細(xì)教程
在生產(chǎn)環(huán)境下,mysql的數(shù)據(jù)、索引都會(huì)很大,而mysql的默認(rèn)存儲(chǔ)路徑是/val/lib/mysql,這就出現(xiàn)了問題,下面這篇文章主要給大家介紹了關(guān)于MySQL數(shù)據(jù)存儲(chǔ)路徑修改的超詳細(xì)教程,需要的朋友可以參考下2023-03-03MySQL定時(shí)執(zhí)行腳本(計(jì)劃任務(wù))命令實(shí)例
在mysql中我們可以直接進(jìn)行一些參數(shù)設(shè)置讓它成定時(shí)為我們執(zhí)行一些任務(wù)了,這個(gè)雖然可以使用windows或者linux中的計(jì)劃任務(wù)實(shí)現(xiàn),但是mysql本身也能完成2013-10-10