操作员'&&';不能应用于类型为';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)&amp;isValid==true,如果isValid为"null",则为false。感谢

操作员'&&';不能应用于类型为';bool';和';bool';

您必须将其括在括号中:

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