Linq VAR和Typed对象

时间:2011-03-03 14:06:49

标签: c# asp.net linq 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;

此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

7 个答案:

答案 0 :(得分:7)

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

如果您想存储单个对象,则应使用SingleSingleOrDefaultFirstFirstOrDefault等方法。

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

四种方法的区别在于:

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

(来自MSDN的定义)

答案 1 :(得分:5)

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

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

答案 2 :(得分:5)

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

答案 3 :(得分:3)

linq查询不返回记录,而是返回仅包含1个元素的记录的集合。如果要获取第一个元素,并且如果您确定集合中只有1个元素,请使用单个扩展方法:

var querySlotOrders = from slot in context.CmsSlots
                      where slot.SlotId == myCurrentSlotId
                      select slot;
var querySlotOrder = querySlotOrders.Single();

if (querySlotOrder.SlotOrder == myNewSlotOrder)
    e.Cancel = true;

答案 4 :(得分:2)

正如Dennis在他的回答中指出的那样,你没有得到一个对象的实例,你从查询中得到一个IEnumerable。要访问SlotOrder属性,您需要从集合中选择一个特定项目,很可能是第一个 - 根据您的查询判断。

答案 5 :(得分:0)

这是madd0的代码,但重新格式化为使用C#样式而不是SQL样式

var querySlotOrder = context.CmsSlots
  .Where(slot => slot.SlotId == myCurrentSlotId)
  .Single();

最好阅读并理解SQL样式

答案 6 :(得分:-3)

为什么使用var?如果您知道对象的类型,则应键入querySlotOrder

MyObjectType querySlotOrder = (from slot in context.CmsSlots
                             where slot.SlotId == myCurrentSlotId
                             select slot).FirstOrDefault();

           if (querySlotOrder.SlotOrder == myNewSlotOrder)
                e.Cancel = true;