- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我想让我的代码更好。我可以安全地将第一个示例重写为第二个示例吗?
IQueryable<PDF> pdfList = (from pdfobj in pdfDataContext.PDFs
where pdfobj.Id == pdfId
select pdfobj);
if (pdfList.Count() > 0)
{
PDF pdfOldWay = pdfList.FirstOrDefault();
pdfOldWay. // do something. (pdfOldWay can't be null here...)
}
--
PDF pdfNewWay = (from pdfobj in pdfDataContext.PDFs
where pdfobj.Id == pdfId
select pdfobj).SingleOrDefault();
if (pdfNewWay != null)
{
// do something
}
--
编辑:
抱歉没说清楚。我的问题是直接获取 PDF 对象,而不必先使用列表。我不想检查计数是否大于 0,因为它看起来不太好。
最佳答案
是的,这看起来很安全。您还可以稍微简化您的查询:
PDF pdfNewWay = pdfDataContext.PDFs.SingleOrDefault(p => p.Id == pdfId);
if (pdfNewWay != null)
{
// do something
}
SingleOrDefault 和 FirstOrDefault 之间的唯一区别是,如果找到多个匹配项,SingleOrDefault 将抛出异常,因此除非您想要此检查,否则您最好坚持使用 FirstOrDefault。
关于c# - SingleOrDefault() 的最佳实践,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4545174/
每当我这样获取时,我都会遇到异常 Feature f = o.Features.SingleOrDefault(e => e.LinkName == PageLink); 因为这可以返回一个或多个元素
SingleOrDefault返回null,但是如果我想分配值来表示未找到的对象怎么办? 最佳答案 你可以做类似的事情 myStrings.DefaultIfEmpty("myDefaultStrin
考虑一个在不同位置有多台计算机的环境。这些计算机运行着一个 Windows 应用程序,并有一个计时器每 5 分钟检查一次同步新数据。信息通过互联网连接同步到一个集中位置。客户端计算机和中央服务器上的数
我有一个调用 SingleOrDefault 方法 3 次并在任何序列具有多个匹配元素时记录异常的代码。 如果我想检查这段代码的哪一部分抛出异常,问题就开始了。 是否可以从此异常中获取一些有用的信息,
我的以下查询 var varUser = (from d in db.tblUsers where (d.ID == intID) select d).SingleOrDefault(); ret
我想让我的代码更好。我可以安全地将第一个示例重写为第二个示例吗? IQueryable pdfList = (from pdfobj in pdfDataContext.PDFs
我偶然发现了一个有趣的场景,但我找不到解决方案。假设我必须找到序列中的主数(至少出现 n/2 + 1 次的数字,其中 n 是序列的大小)。这是我的实现: public static int FindM
类似于this问题 - 编写 LINQ 的 SingleOrDefault 最惯用的方法是什么?在 F# 中? 最佳答案 如果您希望函数在序列为空时返回null(或值类型的默认值),只需继续并调用现有
我正在尝试执行以下操作... Request request = ( from r in db.Requests where r.Status == "Processing" &&
所以,如果我有一个像这样的简单类: class Color { public int ID { get; set; } public string ColorName { get; s
在我们的项目中,我经常遇到诸如“序列包含多个元素”之类的非信息性消息。它时常发生。 检查一下不是更好吗: var count = collection.Count(i => predicate); i
考虑这些代码行: //prodProdGroup is a list within the itm object that I need to search. The items //with
我回答了一些问题并在谷歌上搜索了一下,但我找不到答案(这让我很满意)。 基本上,我理解 SingleOrDefault 返回 null 或 0(取决于类型)。 但是我怎样才能让它返回其他东西呢? re
在 Typescript 中,我经常使用这种模式: class Vegetable { constructor(public id: number, public name: string)
我正在添加参数以将信息插入数据库并遇到潜在的空引用异常。通过使用 SingleOrDefault LINQ 表达式,我认为如果实例没有名为“Name”的 Tag,则 Tag 将默认为空值。只要实例具有
我有下面这行,但仍然得到一个异常“序列包含多个元素” Details rd = this.db.Details.SingleOrDefault(x => x.TId == Id && x.TypeId
我之前写的一些代码使用了 Find()通过主键检索单个实体的方法: return myContext.Products.Find(id) 这很有效,因为我将这段代码放入一个通用类中,并且每个实体都有一
我正在测试以下语句中是否存在用户记录: if (fromUser.AllFriends.Where(af => af.FriendUserID == toUserID).SingleOrDefault
对于上述和/或包括其他方法,如果您正在搜索一条记录,并且只有一条记录存在,那么哪一条执行速度最快?例如,我想确保一旦找到正在查询的值,我正在寻找一个能够立即返回该值而无需搜索剩余记录的值。 最佳答案
我正在使用 EF 开发 ASP.NET MVC 4.5 网站。我有代码检查数据库中的记录是否存在,如果不存在,则创建一个新记录。由于我的代码中存在问题(随后已修复),我在不到一秒的时间内调用了该代码两
我是一名优秀的程序员,十分优秀!