我有一个非常简单的辅助方法来生成唯一的代码。为了确保代码是唯一的,我执行了一个 LINQ to Entities 查询来验证它是否已经被使用。
我第一次尝试编写这种方法时效果很好:
public string GenerateUniqueSignUpCode()
{
while( true )
{
var code = Path.GetRandomFileName().Substring( 0, 6 ).ToUpper();
if( !Context.Users.Any(e => e.SignUpCode.ToUpper() == code) )
return code;
}
}
但是,R# 建议可以简化 LINQ 表达式,从而产生了这种方法:
public string GenerateUniqueSignUpCode()
{
while( true )
{
var code = Path.GetRandomFileName().Substring( 0, 6 ).ToUpper();
if( Context.Users.All(e => e.SignUpCode.ToUpper() != code) )
return code;
}
}
这种重写会导致无限循环。运行代码时,数据库不包含任何 6 字符代码,因此它应该在第一次尝试时退出循环(如第一个方法所示)。
EF 4.3.1 中的 All 是否损坏或发生了什么?