- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在开发一个 asp.net mvc-4 web 应用程序,我正在使用 Entity Framework 5。现在我有以下模型方法:-
public IQueryable<TMSStorageDevice> CustomerSD(int customerid)
{
var customerSiteIds = entities.SiteDefinitions.Where(a => a.AccountDefinitions1.SingleOrDefault().ORG_ID == customerid).Select(a2 => a2.SITEID).ToList();
}
现在这将引发以下错误:-
System.NotSupportedException was unhandled by user code
HResult=-2146233067
Message=The methods 'Single' and 'SingleOrDefault' can only be used as a final query operation. Consider using the method 'FirstOrDefault' in this instance instead.
Source=System.Data.Entity
StackTrace:
at System.Data.Objects.ELinq.ExpressionConverter.MethodCallTranslator.SingleTranslatorBase.TranslateUnary(ExpressionConverter parent, DbExpression operand, MethodCallExpression call)
at System.Data.Objects.ELinq.ExpressionConverter.MethodCallTranslator.UnarySequenceMethodTranslator.Translate(ExpressionConverter parent, MethodCallExpression call)
at System.Data.Objects.ELinq.ExpressionConver
我能够通过替换 (SingleOrDefault()
) 来解决这个问题:-
a.AccountDefinitions1.SingleOrDefault().ORG_ID
与 (FirstOrDefault()
):-
a.AccountDefinitions1.FirsteOrDefault().ORG_ID
所以任何人都可以对这种行为提出建议吗?我的意思是为什么 FirstOrDefault()
在这种情况下会与 SingleorDefault()
不同?
最佳答案
因为 SingleOrDefault
会要求它生成 SQL,以确保不超过 1 个外部行。本质上,如果计数 > 1
FirstOrDefault
仅允许它生成连接和 SELECT TOP 1
(或等效项),这要容易得多。
它只是没有在 EF 中实现。
关于c# - 在 .Where() 中使用 .SingleOrDefault() 将引发以下异常 :- System. NotSupportedException 未被用户代码处理,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33883680/
每当我这样获取时,我都会遇到异常 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 网站。我有代码检查数据库中的记录是否存在,如果不存在,则创建一个新记录。由于我的代码中存在问题(随后已修复),我在不到一秒的时间内调用了该代码两
我是一名优秀的程序员,十分优秀!