1. 程式人生 > >SQL中的cast()函數

SQL中的cast()函數

lin 最小 錯誤信息 通過 variant 數據類型轉換 -i 語法 col

  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

實例:

select * from vrv_paw_genuineManagementStatic where softId=8 ORDER BY cast(version AS decimal(9,2)) desc limit 0,1

技術分享

select max(CAST(version AS DECIMAL(9,2))) from vrv_paw_genuineManagementStatic where softId=8

技術分享

SQL中的cast()函數