操作员'&&';不能应用于类型为';bool';和';bool';
本文关键字:bool amp 不能 操作员 应用于 类型 | 更新日期: 2023-09-27 18:26:50
尝试读取类似的dataContext类
var users = new List<User>();
var roles = new int[] { 1, 2 };
// here I need to get users who's role is in role (1, 2), hence above line
// and also I need to get user who's isValid field true, please note that isValid is SQL 'bit' field and is nullable
//This is what I am doing
foreach (var user in dataContext.Users
.Where(u => roles.Contains(u.RoleID.Value)
&& u.isValid ?? false == true)) // here '&&' part I'm struggling and getting above error
{
users.Add(new User()
{
// Users Added in collection
});
}
所以问题是在where子句中,我需要得到角色(1,2)&;isValid==true,如果isValid为"null",则为false。感谢
您必须将其括在括号中:
roles.Contains(u.RoleID.Value) && (u.isValid ?? false)
与(u.isValid??false)有点混淆,这不意味着如果u.isValid==null,然后将其设为false,并在其中查找用户u.isValid为false,这不是我想要的。
不,这只是意味着nulls
被视为false
,并且所有用户都被占用,其中isValid
既不是null
也不是false
。它之所以有效,是因为??
-运算符将Nullable<bool>
转换为bool
,所以您可以将它与&&
一起使用。我不喜欢它,我更喜欢稍后理解的显式代码:
roles.Contains(u.RoleID.Value) && u.isValid.HasValue && u.isValid.Value
或者通过使用CCD_ 10-算子和bool?
:来简化
roles.Contains(u.RoleID.Value) && u.isValid == true
给定bool
将默认为false
,您可以使用GetValueOrDefault
roles.Contains(u.RoleID.Value) && u.isValid.GetValueOrDefault()
注意-EF似乎不支持GetValueOrDefault
-请参阅票证
您可以这样尝试。
foreach (var user in dataContext.Users
.Where(u => roles.Contains(u.RoleID.Value)
&& (u.isValid ?? false))) // note the bracket around (u.isValid ?? false)
或
foreach (var user in dataContext.Users
.Where(u => roles.Contains(u.RoleID.Value)
&& (u.isValid.HasValue && u.isValid))) //you can use HasValue to check for null