對於(&&,||),運算的對象是邏輯值,也就是True/False &&至關與中文的而且,||至關於中文的或者 。(叫作邏輯運算符又叫短路運算符) 運算結果只有下列四種狀況。 True && True = True (左邊爲true,再驗證右邊也爲true,返回結果true)假如這是一個查詢條件,則執行。 True && False = False (左邊爲true,再驗證右邊爲false,返回結果false)假如這是一個查詢條件,不執行。 False && True = False (左邊爲false,發生短路現象。右邊再也不執行,直接返回false).........一樣不執行。 False && False = False (同上) True || True = True (左邊爲true,發生短路現象,右邊不執行,直接返回true).......執行 True || False = True (左邊爲true,發生短路現象,右邊不執行,直接返回true).......執行 False || True = True (左邊爲false,再驗證右邊爲true,返回結果true)............執行 False || False = False (左邊爲false,再驗證右邊也爲false,返回結果false).......不執行
對於(&,|),運算的對象是位,也就是1/0,叫作位運算符 理解:0爲false,1爲true(通用:0表示假,全部非零的數表示真。 ######方便記憶:0,什麼都沒有騙人的,則爲假) 運算結果只有下列四種狀況。 1 & 1 = 1 1 & 0 = 0 0 & 1 = 0 0 & 0 = 0 1 | 1 = 1 1 | 0 = 1 0 | 1 = 1 0 | 0 = 0 &&和&對於他們各自的運算對象來講,結果是同樣的。
下面用一段代碼來講明||在實際代碼中的運用數據庫
var data = svc.DeclarationHeads.Include("TaxType").Where(f => f.CorporationCode == param.CorporationCode && f.FlowSign == 2 && (!param.TaxTypeId.HasValue || f.TaxTypeId == param.TaxTypeId)).ToList();
當傳入的參數中TaxTypeId==null時,param.TaxTypeId.HasValue爲true,發生短路現象,右邊不執行,返回結果true。code
則實際執行代碼:var data = svc.DeclarationHeads.Include("TaxType").Where(f => f.CorporationCode == param.CorporationCode && f.FlowSign == 2 ).ToList();
當傳入的參數中TaxTypeId==123時,param.TaxTypeId.HasValue爲false,執行右邊的代碼,即f.TaxTypeId == 123, 對象
則實際執行代碼:var data = svc.DeclarationHeads.Include("TaxType").Where(f => f.CorporationCode == param.CorporationCode && f.FlowSign == 2 && f.TaxTypeId == 123 ).ToList();
適用範圍:當咱們再勾選條件進行查詢或者操縱數據庫時,能夠任意選擇條件個數進行查詢,而只需調用同一個方法。(即一個服務完成多重條件的查詢)減小冗餘代碼。blog