我想要一个代码示例。 目前我在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
答案 0 :(得分:7)
即使您的查询返回单个对象,您在幕后使用的Select
方法也不会。它在EF中返回IQueryable<T>
。
如果您想存储单个对象,则应使用Single
,SingleOrDefault
,First
,FirstOrDefault
等方法。
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;