运算符'&&'不能应用于'bool'和'bool?'类型的操作数

sky*_*sky 6 c# linq

试图像这样读取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
    });
}
Run Code Online (Sandbox Code Playgroud)

所以问题在于where子句我需要获得角色的用户(1,2)&& isValid == true,如果isValid为'null'则使其为false.谢谢

Tim*_*ter 23

你必须将它包装在括号中:

roles.Contains(u.RoleID.Value) && (u.isValid ?? false)
Run Code Online (Sandbox Code Playgroud)

有点困惑(u.isValid ?? false),这是不是意味着如果u.isValid == null然后将其设为false并查找u.isValid为false的用户,这不是我想要的.

不,它只是意味着nulls被视为false并且所有用户都被视为既不是也不isValidnull.它的工作原理是因为false-operator将其转换??为a Nullable<bool>,所以你可以使用它bool.我不喜欢它,我更喜欢后面理解的显式代码:

roles.Contains(u.RoleID.Value) && u.isValid.HasValue && u.isValid.Value
Run Code Online (Sandbox Code Playgroud)

或者使用&&-operator 更简单==:

roles.Contains(u.RoleID.Value) && u.isValid == true
Run Code Online (Sandbox Code Playgroud)

  • 但是失去了`== true` (6认同)
  • 有点困惑(u.isValid ?? false),这是不是意味着如果u.isValid == null然后将其设为false并查找u.isValid为false的用户,这不是我想要的. (2认同)

Jam*_*mes 6

鉴于bool将默认false反正你可以使用GetValueOrDefault

roles.Contains(u.RoleID.Value) && u.isValid.GetValueOrDefault()
Run Code Online (Sandbox Code Playgroud)

注意 - GetValueOrDefaultEF似乎不支持 - 请参阅票证


sud*_*u63 2

你可以这样尝试。

 foreach (var user in dataContext.Users
          .Where(u => roles.Contains(u.RoleID.Value) 
             && (u.isValid ?? false))) // note the bracket around (u.isValid ?? false)
Run Code Online (Sandbox Code Playgroud)

或者

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
Run Code Online (Sandbox Code Playgroud)