草庐IT

dynamic-queries

全部标签

c# - Entity Framework : Precompiled Query for Enumerable. 包含

EntityFramework5+应该预编译所有查询。但是,对于诸如Listids;varentities=context.MyEntities.Where(x=>ids.Contains(x.Id)).ToArray();EntityFramework无法预编译查询,并且根据整个查询的复杂性,将表达式树解析为SQL可能会耗费数秒。有没有人找到解决方法来获取预编译查询?我真的不明白为什么会这么难;当然很难用参数来做,因为元素的数量可能不同,但是有像SQL这样的SQL就足够了SELECTa,b,cfromMyEntitiesWHEREcin__PLACEHOLDER__然后用实际的列表元

c# - 在 C# 的 Dynamic Linq 中使用 "Contains"关键字查询数据

在C#的动态linq中执行具有“包含”关键字的查询时,我遇到了一些问题。我收到以下错误“Int32”类型中不存在任何属性或字段我的代码如下:如果我为数据类型字符串字段使用“包含”关键字,那么它可以正常工作,如下所示string[]CandidateNamesArray=newstring[]{"Ram","Venkat","Micheal"}vardynamicLinqQuery=Candidates.Where("CandidateName.Contains(@0)",CandidateNamesArray);工作正常但是如果我对数据类型int字段使用“Contains”关键字,那么

c# - 错误 : An expression tree may not contain a dynamic operation

我使用Asp.Net4和C#,我使用EF4。我有这个查询,我收到一个错误:Anexpressiontreemaynotcontainadynamicoperationdynamico=e.Item.DataItem;varimagesContent=context.CmsImagesContents.FirstOrDefault(img=>img.ContentId==o.ContentId);使用Lamba表达式转换动态类型似乎是不可能的。如何解决这个问题,并能够在我的Lamba中使用我的对象o?谢谢附言:e.Item.DataItem属于CmsContent类型并且o.Conten

c# - 运算符 'op ' 不能应用于类型 'dynamic' 和 'lambda expression' 的操作数

我似乎无法将二元运算应用于lambda表达式、委托(delegate)和方法组。dynamicMyObject=newMyDynamicClass();MyObject>>=()=>1+1;第二行给出错误:Operator'>>='cannotbeappliedtooperandsoftype'dynamic'and'lambdaexpression'为什么?运算符功能不是由我的自定义TryBinaryOperation覆盖决定的吗? 最佳答案 这不是MyDynamicClass的问题,问题是您不能将lambda表达式作为动态表达式

c# - C# 4.0 中 "dynamic"变量的实际用途是什么?

如果调用方法时它可能不存在,它们有什么用?这是否意味着您可以在动态对象上动态创建方法?这个有什么实际用途? 最佳答案 您实际上无法动态创建该方法-但您可以获得IDynamicMetaObject的实现(通常通过扩展DynamicObject)来响应如果该方法存在。用途:使用弱API(例如office)针对COM对象进行编程调用Ruby/Python等动态语言可能制作“可探索的”对象-想象一个类似XPath的查询,但通过方法/属性调用,例如document.RootElement.Person[5].Name["Attribute"]

c# - SQL 服务器 : invalid object name in query execution

我正在尝试执行Insert语句,但一直收到Invalidobjectname错误。这是我的代码:publicstringaddNewComment(intuserID,intpageID,stringtitle,stringcomment){stringquery="INSERTINTOdbo.nokernok_kommentarer(userID,pageID,commentTitle,comment)"+"VALUES("+userID+","+pageID+",'"+title+"','"+comment+"')";adapter.InsertCommand=newSqlComm

c# - 为什么 dynamic 关键字不能用于动态加载的程序集?

我正在开发一个CSharp表达式求值器,您可以在下面看到它的用途。该组件生成代码并在内存中对其进行编译,然后加载生成的程序集,创建生成类的实例并运行它。结果保存在字典中。我的问题是所有运行正常,直到最后一行代码失败并出现异常:Microsoft.CSharp.RuntimeBinder.RuntimeBinderException'object'doesnotcontainadefinitionfor'FirstName'.但是,VisualStudio能够向我展示专业的变量内容:Professional={FirstName=JuanPablo,LastName=Ibañez,Cer

c# - 新手 LINQ 问题 : Is Paging in LINQ Queries Possible?

是否可以在Linq查询中使用“分页”功能?假设我有一些这样的XML:ChoiceOneChoiceTwoChoiceThree...ChoiceForty-EightChoiceForty-NineChoiceFifty如果我想实现分页功能,我是否能够为LINQ查询提供一个偏移量,以便我可以从第11个元素开始并在第20个元素结束?如果是这样,如果数据是对象列表而不是XML,查询会有什么不同吗? 最佳答案 varq=fromXinChoices.Skip((page-1)*pageSize).Take(pageSize)selectX

c# - 有没有办法在 lambda 表达式树中使用 `dynamic`?

首先,规范。我们使用MVC5、.NET4.5.1和EntityFramework6.1。在我们的MVC5业务应用程序中,我们有很多重复的CRUD代码。我的工作是“自动化”其中的大部分,这意味着将其提取到基类并使其可重用。现在,我有Controller、View模型和EF6实体模型的基类。所有EF6实体继承的我的抽象基类:publicabstractclassBaseEntitywhereTSubclass:BaseEntity{publicabstractExpression>UpdateCriterion();}UpdateCriterion方法用于AddOrUpdate数据库上下文

c# - 是否有当前等效于停产的 "SQL Server English Query"

我正在寻找一个.net引擎,它提供了一种将自然英语语言查询转换为SQL语法的方法。我知道Microsoft曾经有一个名为“EnglishQuery”的产品,它正是基于口语对SQL和多维数据集查询执行此操作。自SQLServer2000以来,他们已经停止使用它,我希望有一个完全受支持的现代等效产品可用?以前的版本支持语音查询,例如“1996年卖出了多少辆蓝色福特汽车?”变成了SELECTCOUNT(*)FROMCarSalesWHEREMake='Ford'ANDColor='Blue'ANDDATEPART(yy,SalesDate)='1996'原始链接"EnglishQuery"