- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我正在使用 Entity Framework 4.2(代码优先)访问我的数据库。我假设如果我使用 SingleOrDefault
查询一个实体,如果该实体尚未被跟踪,它只会查询数据库,但事实并非如此。另一方面,Find
方法似乎确实在执行此操作。 Find
的问题是它似乎不允许我加载相关数据。
有没有一种方法既可以使用Find
方法又可以快速加载数据?例如,我想加载一本书及其所有评论:
// Load book from the database
Book book = context.Books.Find(1);
context.Entry<Book>(book).Collection<Review>.Load(); // Book.Reviews is now populated
// Load book from the change tracker
// This will include all Reviews as well
Book book2 = context.Books.Find(1);
使用 SingleOrDefault
我可以在使用 Include 获取图书时加载评论:
// Load book + reviews from the database
Book book = Book.Include("Reviews").SingleOrDefault(b => b.Id == 1);
// Doing the same thing again requeries the database
Book book2 = Book.Include("Reviews").SingleOrDefault(b => b.Id == 1);
有没有办法通过 SingleOrDefault
的预加载来获得 Find
的行为?
最佳答案
Find
方法用于按键搜索单个实体。 SingleOrDefault
方法用于执行查询。预先加载只能是真正在数据库上执行的查询的一部分,因此它不能与 Find
一起使用。
作为解决方法,您可以这样重写它:
// This will check only on in-memory collection of loaded entities
Book book = context.Books.Local.SingleOrDefault(b => b.Id == 1);
if (book == null)
{
book = context.Books.Include(b => b.Review).SingleOrDefault(b => b.Id == 1);
}
关于c# - Entity Framework 代码优先查找与 SingleOrDefault(预加载),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10110682/
每当我这样获取时,我都会遇到异常 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 网站。我有代码检查数据库中的记录是否存在,如果不存在,则创建一个新记录。由于我的代码中存在问题(随后已修复),我在不到一秒的时间内调用了该代码两
我是一名优秀的程序员,十分优秀!