SQL中的cast()函數

CAST函數用於將某種數據類型的表達式顯式轉換爲另外一種數據類型。html

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

1、語法:express

  CAST (expression AS data_type)函數

  參數說明:
  expression:任何有效的SQServer表達式。
  AS:用於分隔兩個參數,在AS以前的是要處理的數據,在AS以後是要轉換的數據類型。
  data_type:目標系統所提供的數據類型,包括bigint和sql_variant,不能使用用戶定義的數據類型。spa

 

  用CAST函數進行數據類型轉換時,在下列狀況下可以被接受:
  (1)兩個表達式的數據類型徹底相同。
  (2)兩個表達式可隱性轉換。
  (3)必須顯式轉換數據類型。3d

 

      能夠轉換的類型是有限制的。這個類型能夠是如下值其中的一個:htm

  • 二進制,同帶binary前綴的效果 : BINARY    
  • 字符型,可帶參數 : CHAR()     
  • 日期 : DATE     
  • 時間: TIME     
  • 日期時間型 : DATETIME     
  • 浮點數 : DECIMAL      
  • 整數 : SIGNED     
  • 無符號整數 : UNSIGNED 

 

2、注意事項:blog

(1). CAST()函數的參數是一個表達式,它包括用AS關鍵字分隔的源值和目標數據類型。ci

SELECT CAST('12' AS int)字符串

 

 

 

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

SELECT CAST('12.5' AS int)

 

 

 

注意:CAST()函數和CONVERT()函數都不能執行四捨五入或截斷操做。因爲12.5不能用int數據類型來表示,因此對這個函數調用將產生一個錯誤

 

(3). 要返回一個合法的數值,就必須使用能處理這個值的數據類型。

對於這個例子,存在多個可用的數據類型。若是經過CAST()函數將這個值轉換爲decimal類型,須要首先定義decimal值的精度與小數位數。在本例中,精度與小數位數分別爲9 與2。精度是總的數字位數,包括小數點左邊和右邊位數的總和。而小數位數是小數點右邊的位數。這表示本例可以支持的最大的整數值是9999999,而最小的小數是0.01。

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

 

 

 

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

SELECT CAST('12.5' AS decimal)

 

寫做不易,轉載請備明出處,謝謝!

https://www.cnblogs.com/yifeixue/p/13793257.html

相關文章
相關標籤/搜索