试图像这样读取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并且所有用户都被视为既不是也不isValid是null.它的工作原理是因为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)
鉴于bool将默认false反正你可以使用GetValueOrDefault
roles.Contains(u.RoleID.Value) && u.isValid.GetValueOrDefault()
Run Code Online (Sandbox Code Playgroud)
注意 - GetValueOrDefaultEF似乎不支持 - 请参阅票证
你可以这样尝试。
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)