外鏈接說明、cast() -工作備忘2016/1/19

1、使用left/right outer join 時 ,主表的約束條件不可加在 從表的ON 語句後面,起不到作用

數據庫在通過連接兩張或多張表來返回記錄時,都會生成一張中間的臨時表,然後再將這張臨時表返回給用戶。

      在使用left jion時,on和where條件的區別如下:

1) on條件是在生成臨時表時使用的條件,它不管on中的條件是否爲真,都會返回左邊表中的記錄。

2)where條件是在臨時表生成好後,再對臨時表進行過濾的條件。這時已經沒有left join的含義(必須返回左邊表的記錄)了,條件不爲真的就全部過濾掉。

  其實以上結果的關鍵原因就是left join,right join,full join的特殊性,不管on上的條件是否爲真都會返回left或right表中的記錄,full則具有left和right的特性的並集。 而inner jion沒這個特殊性,則條件放在on中和where中,返回的結果集是相同的


select *  
FROM   DWCN.CMP_ACCOUNT_ACTIVITY ATV
LEFT   OUTER JOIN  DWCN.EMPLOYEE ME ON ATV.ID_EMPLOYS_SOLVE = ME.ID_EMPLOYEE
                                 AND ATV.ID =157 
以左外連接爲例,當使用left join on 時,on的條件對左表(大表)不起作用,
因爲外鏈接只判斷右表(小表)側的數據並返回對應列,對大表是現實全量數據 


引用地址 http://www.cnblogs.com/xcre/archive/2012/03/29/2423681.html

2、

語法:


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

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