亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術(shù)文章
文章詳情頁

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

瀏覽:187日期:2023-05-05 10:11:59

注意:本文使用數(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)嗖僮鳌S捎?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)容請(qǐng)搜索以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持!

標(biāo)簽: MySQL
主站蜘蛛池模板: 日本一级毛片视频网站 | 99久久免费精品高清特色大片 | 国产九色在线播放 | 曰曰啪天天拍视频在线 | 黄网在线看 | 国产精品久久久久久网站 | 欧美日韩一级大片 | 久久网国产 | 嫩草视频在线观看www视频 | 国产成在线观看免费视频成本人 | 一级毛片aaaaaa视频免费看 | 1024国产高清精品推荐 | 911亚洲精品 | 日本xxwwwxxxx网站 | 看色片 | 国产精品爱久久久久久久9999 | 国产精品国产三级在线专区 | 久久免费国产精品一区二区 | 亚洲aⅴ久久久噜噜噜噜 | 国产美女激情视频 | 搞黄视频免费 | 久久97久久99久久综合 | www·麻豆| 99精品国产三级在线观看 | 一极黄色片 | 午夜视频福利在线 | 免费观看欧美性生 | 国产精品视频不卡 | 久久99热精品免费观看无卡顿 | 怡红院免费va男人的天堂 | 欧美黑人换爱交换乱理伦片 | 欧美特级限制片高清 | 免费看黄色网址 | 欧美一级毛片一 | 女人午夜啪啪性刺激免费看 | 国产丝袜脚 | 成年女人毛片免费观看不卡 | 丰满的大乳老师三级在线观看 | 男人综合网 | 国产三级a三级三级午夜 | 久久h|