使用coalesce和nullif的組合來減輕寫sql的工作量
當前位置:點晴教程→知識管理交流
→『 技術文檔交流 』
今天幫朋友調了一個網站,無意中翻了一個sp,看到了一段很長的select語句,這個select語句之所以長,是因為有好幾個一般復雜的case語句跟在select的后面。我們摘取其中的一個字段的邏輯規則和數據來做我們的測試數據: create table tbl (id int, type_a int) insert into tbl values (1000,1000) insert into tbl values (999,999) insert into tbl values (998,998) insert into tbl values (997,997) insert into tbl values (996,996) insert into tbl values (995,null) insert into tbl values (994,null) insert into tbl values (993,null) insert into tbl values (992,null) insert into tbl values (991,null) 邏輯非常簡單:當type_a為997或null的時候,我們要讓輸出的type_a字段值為0。 OK,這個SQL語句當然有多種寫法,朋友的sql是這樣寫的: select case when (type_a is null or type_a=997) then 0 else type_a end as type_a from tbl 如果需要控制的字段一多,那這個及時已經使用了縮進的select也看起來很復雜了,時間久了想改動這個sp的邏輯就有些吃力了,我們常常在做計劃時會說“半小時搞定這個問題”,但是往往在做的時候都會超過這個時間,原因就在于我們總有從一團亂麻中找到入手點。復雜的代碼和邏輯往往是解決問題中難啃的骨頭。那么有什么好辦法優化一下嗎? select coalesce(nullif(type_a,997),0) as type_a from tbl Well,上面寫了6行的sql就被這1行所替代了。 nullif接受兩個參數,如果兩個參數相等,那么返回null,否則返回第一個參數 coalesce接受N個參數,返回第一個不為null的參數 So,當您遇到處理一個如下所示的計算工資的問題的時候,不妨這樣來解決: create table salary (e_id uniqueidentifier, byMonth int, byHalfYear int, byYear int) insert into salary values (newid(),9000,null,null) insert into salary values (newid(),null,60000,null) insert into salary values (newid(),null,null,150000) 每個雇員有3種薪資計算方式(按月,按半年,按年)來發放工資,如果我們想統計每個員工的年薪,那這樣一句就夠了: select e_id,coalesce(byMonth*12,byHalfYear*2,byYear) as salary_amount from salary 結果: e_id salary_amount ------------------------------------ ------------- 8935330D-2B73-4FEF-941A-768D7A8CCB6C 108000 52A3CE16-74FD-4D5D-BB4F-F5F67A1E9D2F 120000 06B6B924-EAB2-4187-B733-EBB56B62E793 150000 參考: COALESCE (Transact-SQL) NULLIF (Transact-SQL) 該文章在 2011/8/2 17:11:42 編輯過 |
關鍵字查詢
相關文章
正在查詢... |