Linq VAR和Typed对象

Gib*_*boK 3 c# linq asp.net entity-framework

我想要一个代码示例.目前我在c#和asp.net 4 ef4中使用linq

       var querySlotOrder = from slot in context.CmsSlots
                             where slot.SlotId == myCurrentSlotId
                             select slot;

           if (querySlotOrder.SlotOrder == myNewSlotOrder)
                e.Cancel = true;
Run Code Online (Sandbox Code Playgroud)

此linq查询仅返回记录.

使用VAR我无法获取Typed对象,我无法访问其属性SlotOrder.

如何更改查询?谢谢你的帮助

有用的主题资源:

http://msdn.microsoft.com/en-us/library/bb384065.aspx

http://msdn.microsoft.com/en-us/library/bb397947.aspx

http://msdn.microsoft.com/en-us/library/bb397678.aspx

mad*_*dd0 7

即使您的查询返回单个对象,Select您在幕后使用的方法也不会.它IQueryable<T>在EF中返回一个.

您应该使用的方法,例如Single,SingleOrDefault,First,FirstOrDefault如果要存储一个对象.

var querySlotOrder = (from slot in context.CmsSlots
                      where slot.SlotId == myCurrentSlotId
                      select slot).Single();
Run Code Online (Sandbox Code Playgroud)

这四种方法的区别在于:

  • Single:返回序列的唯一元素,如果序列中没有一个元素,则抛出异常.
  • SingleOrDefault:返回序列的唯一元素,如果序列为空,则返回默认值; 如果序列中有多个元素,则此方法抛出异常.
  • First:返回序列的第一个元素.
  • FirstOrDefault:返回序列的第一个元素,如果序列不包含元素,则返回默认值.

(来自MSDN的定义)


Den*_*aub 5

LINQ select-statement始终返回可查询的集合.因此,您需要从中获取单个对象.

var querySlotOrder = (from slot in context.CmsSlots
                      where slot.SlotId == myCurrentSlotId
                      select slot).FirstOrDefault();
Run Code Online (Sandbox Code Playgroud)


Aas*_*set 5

返回对象的类型是IQueryable<CmdSlot>(假设CmdSlot是元素的类型),并querySlotOrder获取该类型(这是效果var; var本身不是类型).如果您完全确定结果集合中始终只有一个元素,则可以使用它来检索它querySlotOrder.Single().