对于(&&,||),运算的对象是逻辑值,也就是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。
则实际执行代码: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();
适用范围:当我们再勾选条件进行查询或者操纵数据库时,可以任意选择条件个数进行查询,而只需调用同一个方法。(即一个服务完成多重条件的查询)减少冗余代码。