草庐IT

LINQ_ENABLED

全部标签

c# - Linq-to-Entity 查询的动态谓词

以下Linq-to-Entities查询工作正常:varquery=repository.Where(r=>r.YearProp1.HasValue&&r.YearProp1>=minYear&&r.YearProp1我的数据库有十几个列都报告与年份相关的信息(short?数据类型)。我想对所有这些列重复使用相同的Linq-to-Entities逻辑。像这样的东西:Funcfx=GetYearPropertyFunction();varquery=repository.Where(r=>fx(r).HasValue&&fx(r)>=minYear&&fx(r)这会导致错误:LINQto

c# - 如何在 Linq to SQL 中使用 distinct 和 group by

我正在尝试将以下sql转换为Linq2SQL:selectgroupId,count(distinct(userId))fromprocessroundissueinstancegroupbygroupId这是我的代码:varq=fromiinProcessRoundIssueInstancegroupibyi.GroupIDintogselectnew{Key=g.Key,Count=g.Select(x=>x.UserID).Distinct().Count()};当我运行代码时,我不断收到无效的GroupID。有任何想法吗?似乎distinct把事情搞砸了..这里是生成的sql:

c# - 如何从名称的字符串 [] 创建动态 LINQ 选择投影函数?

使用C#...有什么方法可以从数组中为LINQ选择方法上的投影函数指定属性名称。publicclassAlbum{publicintId{get;set;}publicstringName{get;set;}publicshortRate{get;set;}publicstringGenre{get;set;}publicshortTracks{get;set;}}publicclassClass1{privatevoidSome(){//Exampleofsourcevarnames=new[]{"Id","Name","Tracks"};varquery=myDataContext

c# - 在 System.Linq.Expressions 中不带大小写(但使用默认值)切换

我尝试使用System.Linq.Expressions创建一个switch表达式:varvalue=Expression.Parameter(typeof(int));vardefaultBody=Expression.Constant(0);varcases1=new[]{Expression.SwitchCase(Expression.Constant(1),Expression.Constant(1)),};varcases2=newSwitchCase[0];varswitch1=Expression.Switch(value,defaultBody,cases1);vars

c# - LINQ Count() until,这样效率更高吗?

假设我想检查集合中是否至少有N个元素。这比做更好吗?Count()>=N使用:publicstaticboolAtLeast(thisIEnumerableenumerable,intmax){intcount=0;returnenumerable.Any(item=>++count>=max);}甚至publicstaticboolEquals(thisIEnumerableenumerable,intamount){returnenumerable.Take(amount).Count()==amount;}我如何进行基准测试?//////Returnswhethertheenum

c# - LINQ to SQL 实体列名称属性被 guid 主键忽略

我当时使用LINQtoSQL(SQLServer2005SP3x64)处理一个简单的实体类。[Table(Name="TBL_REGISTRATION")]publicsealedclassRegistration:IDataErrorInfo{[Column(Name="TBL_REGISTRATION_PK",IsPrimaryKey=true,IsDbGenerated=true,AutoSync=AutoSync.OnInsert)]publicGuidRegistrationID{get;privateset;}/*otherpropertiesommitedforbrevi

C#、Linq2Sql : Is it possible to concatenate two queryables into one?

我有一个可查询的,我在其中使用了各种Where和WhereBetween将集合缩小到特定集合的语句。现在我需要添加一种Where||WhereBetween。换句话说,我不能像到目前为止那样将它们链接在一起,因为那样可以用作And。那么,我该怎么做呢?我看到两种可能性:创建两个可查询对象,一个使用Where,另一个使用WhereBetween。然后连接它们。不知道这是否可能?此外,虽然不是我的特殊情况,但你很可能会得到重复项......以某种方式将Where表达式和在WhereBetween中创建的表达式与某种Or合并。第一个,如前所述,我什至不确定是否可能。如果是的话,我不太确定这是

c# - 具有 null 属性的嵌套属性的动态 linq 排序

我正在使用我从here获得的这个动态linqorderby函数.这适用于嵌套属性,所以我可以这样做:varresult=data.OrderBy("SomeProperty.NestedProperty");问题是,如果SomeProperty为空,则在NestedProperty上执行OrderBy会抛出臭名昭著的“对象引用未设置为对象的实例”。我的猜测是我需要自定义以下行来处理异常:expr=Expression.Property(expr,pi);//OrLambdaExpressionlambda=Expression.Lambda(delegateType,expr,arg)

c# - 使用 LINQ ExpressionVisitor 将原始参数替换为 lambda 表达式中的属性引用

我正在为我们系统的一部分编写数据层,该部分记录有关每天运行的自动化作业的信息-作业名称、运行时长、结果等。我正在使用EntityFramework与数据库对话,但我试图对更高级别的模块隐藏这些细节,并且我不希望实体对象本身被暴露。但是,我想让我的界面在用于查找工作信息的标准方面非常灵活。例如,用户界面应该允许用户执行复杂的查询,例如“给我所有在上午10:00到11:00之间运行但失败的名为‘hello’的作业”。显然,这看起来像是动态构建的工作Expression树。所以我希望我的数据层(存储库)能够接受类型为Expression>的LINQ表达式。(lambda表达式)然后在幕后将该

c# - 如果使用可为空的 int 变量,LINQ 返回 0 个结果,如果使用 "null",则返回准确的结果

我有一个名为“test”的表,它只有1列,“NullableInt”(可为空的int类型)记录为:1、2、nullint?nullableInt=null;vart=db.tests.Where(x=>x.NullableInt==null).ToList();//returns1recordvart2=db.tests.Where(x=>x.NullableInt==nullableInt).ToList();//returns0records出于某种原因,t2返回0条记录,即使它使用了值为null的“nullableInt”变量,就像t与“null”进行比较一样如有任何帮助,我们将