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
即使您的查询返回单个对象,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的定义)
LINQ select
-statement始终返回可查询的集合.因此,您需要从中获取单个对象.
var querySlotOrder = (from slot in context.CmsSlots
where slot.SlotId == myCurrentSlotId
select slot).FirstOrDefault();
Run Code Online (Sandbox Code Playgroud)
返回对象的类型是IQueryable<CmdSlot>
(假设CmdSlot
是元素的类型),并querySlotOrder
获取该类型(这是效果var
; var
本身不是类型).如果您完全确定结果集合中始终只有一个元素,则可以使用它来检索它querySlotOrder.Single()
.
归档时间: |
|
查看次数: |
1847 次 |
最近记录: |