sql---cast函數

SQL中的cast()函數

本文導讀:CAST函數用於將某種數據類型的表達式顯式轉換爲另一種數據類型。CAST()函數的參數是一個表達式,它包括用AS關鍵字分隔的源值和目標數據類型。

一、語法:


CAST (expression AS data_type)


參數說明:

expression:任何有效的SQServer表達式。

AS:用於分隔兩個參數,在AS之前的是要處理的數據,在AS之後是要轉換的數據類型。

data_type:目標系統所提供的數據類型,包括bigint和sql_variant,不能使用用戶定義的數據類型。

使用CAST函數進行數據類型轉換時,在下列情況下能夠被接受:

(1)兩個表達式的數據類型完全相同。
(2)兩個表達式可隱性轉換。
(3)必須顯式轉換數據類型。

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

如果轉換時沒有指定數據類型的長度,則SQServer自動提供長度爲30。

二、注意事項:

(1).CAST()函數的參數是一個表達式,它包括用AS關鍵字分隔的源值和目標數據類型。以下例子用於將文本字符串'12'轉換爲整型:

SELECT CAST('12' AS int)

(2).返回值是整型值12。如果試圖將一個代表小數的字符串轉換爲整型值,又會出現什麼情況呢?

SELECT CAST('12.5' AS int)

(3).CAST()函數和CONVERT()函數都不能執行四捨五入或截斷操作。由於12.5不能用int數據類型來表示,所以對這個函數調用將產生一個錯誤:

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

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

decimal數據類型在結果網格中將顯示有效小數位: 12.50

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

SELECT CAST('12.5' AS decimal)

    結果是一個整數值:12

以下是一些數據類型的總結:

varchar數據類型VARCHAR是一種比CHAR更加靈活的數據類型,同樣用於表示字符數據,但是VARCHAR可以保存可變長度的字符串。其中M代表該數據類型所允許保存的字符串的最大長度,只要長度小於該最大值的字符串都可以被保存在該數據類型中。因此,對於那些難以估計確切長度的數據對象來說,使用VARCHAR數據類型更加明智。VARCHAR數據類型所支持的最大長度也是255個字符


INT數據類型用於保存從- 2147483647 到2147483648範圍之內的任意整數數據。如果用戶使用Unsigned選項,則有效數據範圍調整爲0-4294967295。舉例如下:

light_years INT;

按照上述數據類型的設置,-24567爲有效數據,而3000000000則因爲超出了有效數據範圍成爲無效數據。

FLOAT [(M,D)]

FLOAT數據類型:用於表示數值較小的浮點數據,可以提供更加準確的數據精度。其中,M代表浮點數據的長度(即小數點左右數據長度的總和),D表示浮點數據位於小數點右邊的數值位數。

舉例如下:

rainfall FLOAT (4,2);

按照上述數據類型的設置,42.35爲有效數據,而324.45和3.542則因爲超過數據長度限制或者小數點右邊位數大於規定值2成爲無效數據。

DATE

DATE數據類型:用於保存日期數據,默認格式爲YYYY-MM-DD。MySQL提供了許多功能強大的日期格式化和操作命令,本文無法在此一一進行介紹,感興趣的讀者可以參看MySQL的技術文檔。

DATE數據類型舉例如下:

the_date DATE;

TEXT / BLOB

TEXT和BLOB數據類型可以用來保存255 到65535個字符,如果用戶需要把大段文本保存到數據庫內的話,可以選用TEXT或BLOB數據類型。TEXT和BLOB這兩種數據類型基本相同,唯一的區別在於TEXT不區分大小寫,而BLOB對字符的大小寫敏感。

SET

SET數據類型是多個數據值的組合,任何部分或全部數據值都是該數據類型的有效數據。SET數據類型最大可以包含64個指定數據值。

舉例如下:

transport SET ("trUCk", "wagon") NOT NULL;

根據上述數據類型的設置,truck、wagon、以及truck,wagon都可以成爲transport的有效值。

ENUM

ENUM數據類型和SET基本相同,唯一的區別在於ENUM只允許選擇一個有效數據值。例如:

transport ENUM ("truck", "wagon") NOT NULL;

根據上述設置,truck或wagon將成爲transport的有效數據值。    



發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章