草庐IT

Linq2XSD

全部标签

C# linq 联合问题

谁能解释一下LINQ中的Union是如何工作的?据说它合并了两个序列并删除了重复项。但我能否以某种方式自定义重复删除行为-假设我希望在重复的情况下使用第二个序列中的元素或第一个序列中的元素。或者即使我希望以某种方式将这些值组合到结果序列中?应该如何实现?更新我想我对问题的描述不正确,假设我们有一些值(value):classValue{StringnameIntwhatever;}并且使用的比较器执行x.name==y.name检查。假设有时我知道我应该从第二个序列中获取元素,因为它的whatever字段比第一个序列的whatever字段更新/更好.无论如何,我会使用方法的sequen

c# - LINQ to Entities - 多个 OrderBy 方法不起作用

如果我对查询应用两个OrderBy方法,就像这样query.OrderBy(rec=>rec.Name).OrderByDescending(rec=>rec.Title);然后只应用第二种方法,第一种方法被忽略。这是一个错误吗?如果我需要对一列进行升序排序而对另一列进行降序排序怎么办?方法语法根本无法实现吗? 最佳答案 试试这个:query.OrderBy(rec=>rec.Name).ThenByDescending(rec=>rec.Title);您的第二个OrderBy正在重置您的第一个结果集。这就是存在ThenBy扩展的原

c# - Linq 加入 COUNT 个

我有2个表,论坛和帖子。我想用一个新的额外字段检索所有论坛字段:计算属于该论坛的所有帖子。我现在有这个:varv=(fromforuminForumsjoinpostinPostsonforum.ForumIDequalspost.Forum.ForumIDselectnew{forum,//Needtoretrieveallfields/columnsfromforumPostCount=//countallpostthatbelongtothisforumwithacondition:countitonlyifpost.Showit==1}).Distinct()连接必须是左连接:

c# - Linq:只为 Where 和 OrderBy 调用相同的方法一次而不是两次?

我有一个简单的linq查询,我需要在一定距离内过滤商店,并根据距离计算结果排序,你懂的。因此,我暂时调用了两次GetDistance方法。如何优化代码以在每个商店只调用一次?doubledistance=50;varresult=stores.Where(s=>Helper.GetDistance(lat,lon,s.Lat,s.Lon)Helper.GetDistance(lat,lon,s.Lat,s.Lon)).ToList(); 最佳答案 一些人(我)觉得更容易阅读的与Yuriy的回答等价的是:doublemaxDistan

c# - 具有直接用户输入的动态 LINQ,有什么危险吗?

我在ASP.NETMVC应用程序中有一个表,我想使用AJAX对其进行排序(服务器端)和过滤。我希望它在其他地方相当容易使用,并且不想将排序和过滤硬编码到查询表达式中,所以我寻找一种动态构建表达式的方法,我发现最好的方法是使用DynamicLINQ.来自如下URL的用户输入直接插入到动态Where或OrderBy中。/Orders?sortby=OrderID&order=desc&CustomerName=Microsoft这将导致两个表达式:OrderBy("OrderIDdescending")Where(@"CustomerName.Contains(""Microsoft"")

c# - LINQ to Entities/LINQ to SQL : switching from server (queryable) to client (enumerable) in the middle of a query comprehension?

在许多情况下,我想在服务器端进行一些过滤(有时是投影),然后切换到客户端以执行LINQ提供程序本身不支持的操作。天真的方法(这基本上就是我现在所做的)是将其分解为多个查询,类似于:varfromServer=fromtincontext.Tablewheret.Col1=123wheret.Col2="blah"selectt;varclientSide=fromtinfromServer.AsEnumerable()wheret.Col3.Split('/').Last()=="whatever"selectt.Col4;但是,很多时候,这带来的代码/麻烦多于它的实际值(value)

c# - Webforms 数据绑定(bind)与 EF Code-First Linq 查询错误

在这个例子中here,Scott展示了对dbContext执行Linq查询并将结果直接绑定(bind)到GridView以显示产品列表。他的示例使用了CodeFirst的CTP4版本。但是,当我尝试使用最新版本的EntityFramework4.1做同样的事情时,我收到以下错误:Databindingdirectlytoastorequery(DbSet,DbQuery,DbSqlQuery)isnotsupported.InsteadpopulateaDbSetwithdata,forexamplebycallingLoadontheDbSet,andthenbindtolocald

c# - Linq to Entity 从 DateTime 获取日期

varislemList=(fromislinentities.Islemlerwhere(isl.KayitTarihi.Date>=dbas&&isl.KayitTarihi.Value.Date它给出错误:LINQtoEntities不支持日期...我如何在linq中获取日期。 最佳答案 使用EntityFunctions.TruncateTime. 关于c#-LinqtoEntity从DateTime获取日期,我们在StackOverflow上找到一个类似的问题:

c# - 如何使用 LINQ 方法语法计算子集合的项数?

假设我有一个模式,表示问题实体。每个问题都可以投赞成票、投反对票,或者当然,根本不投票——就像在StackOverflow中一样。我想获得给定用户的投票数。intnumber=(fromqinuserDbContext.Questionsfromqvinq.QuestionVoteswhereqv.IsVoteUpselectqv).Count();我想编写相同的查询,但使用方法语法。我如何使用相同的示例执行此操作? 最佳答案 您可以使用SelectMany:userDbContext.Questions.SelectMany(x=

c# - 使用 Linq To SQL 加盐和散列密码

我需要对一些密码进行加盐和哈希处理,以便我可以将它们安全地存储在数据库中。关于如何最好地使用LinqToSQL执行此操作,您有什么建议或想法吗? 最佳答案 在这种情况下,LINQtoSQL没有太多相关性。您可以使用任何您想要的机制,因为您不会在SQL中进行散列和加盐。保存密码的步骤如下:以明文形式接收密码以及用户ID。生成(并记住)盐。将盐与密码文本结合起来,例如放在它前面或附加它。使用哈希函数对结果文本进行哈希处理将用户ID、哈希和盐存储在您的数据库中。验证密码的步骤如下:以明文形式接收密码以及用户ID。从数据库中为提供的用户ID