草庐IT

linq-query-syntax

全部标签

c# - LINQ 在 Take 之后继续

假设我们有一个IEnumerablestuff;有没有一种简洁的方法可以在不重新计算的情况下取n个元素,然后再取m个元素?示例代码:stuff.Take(10);stuff.Skip(10).Take(20);//re-evaluatesstuff我在想的可能是这个(不是工作代码)varit=stuff.GetEnumerator();it.Take(10);it.Take(20);编辑以增加难度并澄清我想要完成的事情的复杂性:我想在Take之后继续查询,即it.Take(10);varcont=it.Select(Mutate);cont.Take(20);cont=cont.Whe

c# - Linq 和相等运算符 : Expression of type 'System.Int32' cannot be used for parameter of type 'System.Object'

我试图重写C#中的相等(==)运算符来处理任何类型与自定义类型的比较(自定义类型实际上是null周围的包装器/框)。所以我有这个:internalsealedclassNothing{publicoverrideboolEquals(objectobj){if(obj==null||objisNothing)returntrue;elsereturnfalse;}publicstaticbooloperator==(objectx,Nothingy){if((x==null||xisNothing)&&(y==null||yisNothing))returntrue;returnfal

c# - Linq 到实体 : Unions + Distinct

我不知道如何用不同的方式进行多个联合。当我将.Distinct与IEqualityComparer一起使用时,抛出异常:LINQtoEntitiesdoesnotrecognizethemethod'System.Linq.IQueryable'我的代码是varunion=query.Union(query1).Union(query2);union=union.Distinct(newEqualityComparerTransaction()); 最佳答案 LINQtoEntities不支持采用IEqualityComparer的

c# - LINQ to SQL - 如何高效地对多个条件执行 AND 或 OR 搜索

我有一个ASP.NETMVC站点(它使用LinqToSql作为ORM),并且客户想要一个针对定制数据库的搜索工具,他们可以选择进行“AND”搜索(所有条件匹配)或“或”搜索(任何条件匹配)。该查询非常复杂且冗长,我想知道是否有一种简单的方法可以使它同时执行这两项操作,而无需创建和维护两个不同版本的查询。例如,当前的“AND”搜索看起来像这样(但这是一个大大的简化版本):privateIQueryableGetSampleSearchQuery(SamplesCriteriacriteria){varresults=fromrinTablewhere(r.Id==criteria.Sam

C# 单元测试 - 生成模拟 DataContexts/LINQ -> SQL 类

我热爱C#的新世界,我的玩具程序已经到了我想开始编写一些单元测试的地步。我的代码当前通过DatabaseDataContext对象(*.dbml文件)使用数据库,为此对象创建模拟的最佳方法是什么?考虑到生成数据库LINQ->SQL代码是多么容易以及这一定是一个多么普遍的请求,我希望VS2010内置了有助于测试的功能。如果我偏离了方向并且必须手动完成此操作,您能否告诉我您的首选方法?非常感谢,加文 最佳答案 DataContext的问题在于它不是为模拟而设计的。模拟不可模拟对象的免费工具是MolesfromPex(Pexmoles?)

c# - 如何在运行时从文本构建 LINQ 查询?

我有一个classA{publicintX;publicdoubleY;publicstringZ;//andmorefields/properties...};和一个Listdata并且可以构建一个linq查询,例如varq=fromaindatawherea.X>20selectnew{a.Y,a.Z};然后dataGridView1.DataSource=q.ToList();在我的DataGridView中显示选择。现在的问题是,是否可以根据用户在运行时输入的文本构建查询?喜欢varq=QueryFromText("fromaindatawherea.X>20selectnew

c# - Entity Framework 4 中的简单条件 LINQ 查询

我最近将这段代码迁移到了EntityFramework4,但失败了。显然,如果status没有值,则返回所有匹配项,如果它有值匹配user.StatusID==1。returnusers.SingleOrDefault(user=>user.Username==username&&user.EncryptedPassword==password&&(!status.HasValue||user.StatusID==1));异常返回:ArgumentException:Thespecifiedvalueisnotaninstanceoftype'Edm.Int32'Parameterna

c# - 在 LINQ 中 JOIN 之后选择所有列

我有两个表,Table1和Table2.我想执行左外连接:varmyOutput=fromobject1inTable1joinobject2inTable2onobject1.Property1equalsobject2.Property2intoTable3fromoutputinTable3.DefaultIfEmpty()selectnew{object1.Property1,object1.Property2,//...output.Property3,output.Property4,//...};正如您所注意到的,我想从结果表中选择两个对象的所有属性(连接时考虑的枚举包含

c# - 由于 <AnonymousType>,无法将 .Union 与 Linq 一起使用

我有点被这个问题困扰。希望我能得到一些帮助。这就是重点。我必须用那个SQL请求填充我的DataGridView:SELECTLOT.NumLot,EtatLot,NomEmployeFROMLOTJOINAFFECTATION_LOTonLOT.NumLot=AFFECTATION_LOT.NumLotJOINEMPLOYEonAFFECTATION_LOT.IdEmploye=EMPLOYE.IdEmployeWHEREEtatLot='Libéré'orEtatLot='Suspendu'orEtatLot='Démarré'UNIONSELECTNumLot,EtatLot,nu

C# Linq - 延迟执行

如果我建立一个查询说:(查询是使用System.Xml.Linq中的XDocument类构建的)varelements=fromeincalendarDocument.Root.Elements("elementName")selecte;然后我多次调用elements.Last()。每次调用都会返回最新的Last()元素吗?例如,如果我这样做elements.Last().AddAfterSelf(newXElement("elementName","someValue1"));elements.Last().AddAfterSelf(newXElement("elementName