我正在尝试查询具有特定类型产品的 Art。这是我的艺术模型:
public string Title { get; set; }
public string Description { get; set; }
public List<Product> Products { get; set; }
public string PaintedLocation { get; set; }
从这里我所做的就是以下 LINQ 查询:
List<Art> items = DocumentDbHelper.Client.CreateDocumentQuery<Art>(collection.DocumentsLink)
.Where(i => i.type == "art")
.Where(i => i.Products.Any(p => p.Name == productType))
.AsEnumerable()
.ToList();
我收到以下错误:
"Method 'Any' is not supported."
我转到代码引用的页面以查看 what is supported但我没有看到它说 Any() 不受支持,所以我可能做错了什么。感谢您的帮助。
更新
这对我来说真的很奇怪,所以我将其分解以查看从两个结果返回的内容,以便更好地调试问题:
List<Art> items = DocumentDbHelper.Client.CreateDocumentQuery<Art>(collection.DocumentsLink)
.Where(i => i.Id.Contains("art"))
.AsEnumerable()
.ToList();
items = items.Where(i => i.Products.Any(p => p.Name == productType))
.AsEnumerable()
.ToList();
出于某种原因,这个可行,我不喜欢这个,因为我将它转换为列表,它运行查询两次 - 但它至少证明 Any() 和 Select() 在技术上应该可行.
最佳答案
针对 IQueryable<T> 的 LINQ 查询最大的混淆之一是它们看起来与针对 IEnumerable<T> 的查询完全相同.好吧,前者正在使用 Expression<Func<..>>每当后者使用 Func<..> 时, 但除非有人使用显式声明,否则这不是那么明显并且似乎不重要。然而,最大的不同在于运行时。
一旦IEnumerable<T>查询已成功编译,在运行时它可以正常工作,IQueryable<T> 不是这种情况. IQueryable<T>查询实际上是一个表达式树,由查询提供程序在运行时处理。
一方面,这是一个很大的好处,另一方面,由于在查询编译时不涉及查询提供程序(所有方法都由 Queryable 类作为扩展方法提供),因此无法知道提供者是否支持某些构造/方法直到运行时。使用 Linq to Entities 的人非常了解这一点。更难的是,没有明确的文档说明特定查询提供程序支持什么,更重要的是,它不支持什么(正如您从提供的“支持的内容”链接中注意到的那样)。
解决方案是什么? (以及为什么你的第二个代码有效)
诀窍是针对 IQueryable<T> 编写最大可能的(即查询提供程序支持的)查询部分, 然后切换到 IEnumerable<T>并完成剩下的工作(记住,一旦编译,IEnumerable<T> 查询就可以正常工作)。切换由 AsEnumerable() 执行称呼。这就是为什么您的第二个代码有效 - 因为不受支持 Any DocumentDb 查询提供程序上下文中不再有方法。注意 ToList不需要调用并且查询不会执行两次 - 事实上,这样就没有单个查询,而是两个 - 一个在数据库中,一个在内存中。
所以这样的事情就足够了:
List<Art> items = DocumentDbHelper.Client.CreateDocumentQuery<Art>(collection.DocumentsLink)
.Where(i => i.type == "art")
.AsEnumerable() // The context switch!
.Where(i => i.Products.Any(p => p.Name == productType))
.ToList();
最后,DocumentDb 查询提供程序真正支持什么
文档中的内容不是很清楚,但答案是:确切(且仅)包含在那里的内容。换句话说,唯一受支持的查询运算符(或者更好地说 Queryable 或 Enumerable 扩展方法)是
如您所见,它非常有限。忘记连接和分组运算符,Any , Contains , Count , First , Last等。唯一的好处是它很容易记住 :)
我怎么知道的?好吧,像往常一样,当文档中的内容不清楚时,要么使用试错法,要么使用反编译器。显然在这种情况下前者不适用,所以我使用了后者。如果你好奇,使用你喜欢的反编译器并检查内部类的代码 DocumentQueryEvaluator在Microsoft.Azure.Documents.Client.dll里面.
关于C# LINQ .Any 不适用于 DocumentDb CreateDocumentQuery,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33839854/
大约一年前,我决定确保每个包含非唯一文本的Flash通知都将从模块中的方法中获取文本。我这样做的最初原因是为了避免一遍又一遍地输入相同的字符串。如果我想更改措辞,我可以在一个地方轻松完成,而且一遍又一遍地重复同一件事而出现拼写错误的可能性也会降低。我最终得到的是这样的:moduleMessagesdefformat_error_messages(errors)errors.map{|attribute,message|"Error:#{attribute.to_s.titleize}#{message}."}enddeferror_message_could_not_find(obje
我已经在Sinatra上创建了应用程序,它代表了一个简单的API。我想在生产和开发上进行部署。我想在部署时选择,是开发还是生产,一些方法的逻辑应该改变,这取决于部署类型。是否有任何想法,如何完成以及解决此问题的一些示例。例子:我有代码get'/api/test'doreturn"Itisdev"end但是在部署到生产环境之后我想在运行/api/test之后看到ItisPROD如何实现? 最佳答案 根据SinatraDocumentation:EnvironmentscanbesetthroughtheRACK_ENVenvironm
当我使用has_one时,它工作得很好,但在has_many上却不行。在这里您可以看到object_id不同,因为它运行了另一个SQL来再次获取它。ruby-1.9.2-p290:001>e=Employee.create(name:'rafael',active:false)ruby-1.9.2-p290:002>b=Badge.create(number:1,employee:e)ruby-1.9.2-p290:003>a=Address.create(street:"123MarketSt",city:"SanDiego",employee:e)ruby-1.9.2-p290
我正在使用带有Rails的Devise,我想添加一个方法“getAllComments”,所以我这样写:classUser在我的Controller中:defdashboard@user=current_user@comments=@user.getAllComments();end当我访问我的url时,我得到了undefinedmethod`getAllComments'for#我做错了什么?谢谢 最佳答案 因为getAllComments是一个类方法,而您正试图将其作为实例方法访问。您要么需要访问它:User.getAllCom
我正在使用Rails3.2.3和Ruby1.9.3p0。我发现我经常需要确定某个字符串是否出现在选项列表中。看来我可以使用Ruby数组.includemethod:或正则表达式equals-tildematchshorthand用竖线分隔选项:就性能而言,一个比另一个好吗?还有更好的方法吗? 最佳答案 总结:Array#include?包含String元素,在接受和拒绝输入时均胜出,对于您的示例只有三个可接受的值。对于要检查的更大的集合,看起来Set#include?和String元素可能会获胜。如何测试我们应该根据经验对此进行测试
Ruby初学者努力简单地将这个@@people散列的值打印到控制台classPerson#haveafirst_nameandlast_nameattributewithpublicaccessorsattr_accessor:first_nameattr_accessor:last_name#haveaclassattributecalled`people`thatholdsanarrayofobjects@@people=[]#havean`initialize`methodtoinitializeeachinstancedefinitialize(first_name,last_
这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:AmazonAPIlibraryforPython?我正在寻找一个AmazonAPI,它可以让我:按书名或作者查找书籍显示书籍封面获取有关每本书的信息(价格、评级、评论数、格式、页数等)Python或Ruby库都可以(我只想要最容易使用的库)。有什么建议么?我知道在SO上还有其他一些关于此的帖子,但这些API似乎很快就过时了。[几个月前我尝试了几个建议的Ruby库,但无法让它们中的任何一个工作。]
我刚刚看到whitehouse.gov正在使用drupal作为CMS和门户技术。drupal的优点之一似乎是很容易添加插件,而且编程最少,即重新发明轮子最少。这实际上正是Ruby-on-Rails的DRY理念。所以:drupal的缺点是什么?Rails或其他基于Ruby的技术有哪些不符合whitehouse.org(或其他CMS门户)门户技术的资格? 最佳答案 Whatarethedrawbacksofdrupal?对于Ruby和Rails,这确实是一个相当主观的问题。Drupal是一个可靠的内容管理选项,非常适合面向社区的站点。它
怎样说才是明智的呢?if@thing=="01"or"02"or"03"or"04"or"05"(数字包含在数据类型字符串的列中。) 最佳答案 制作数组并使用.include?if["01","02","03","04","05"].include?(@thing)如果值真的都是连续的,你可以使用像(1..5).include?这样的范围对于字符串,你可以使用:if("01".."05").include?(@thing) 关于ruby-优雅的链式'or'用于测试Ruby中的相同变量,我
我目前正在尝试将ERB布局转换为HAML。这是我不断收到的错误:index.html.haml:18:syntaxerror,unexpected')'));}\n#{_hamlout.format_...这是HAML页面:.row-fluid.span6%h2TodoList.span6%h2{:style=>"text-align:right;"}document.write(today)%hr.divider.row-fluid.span6%h2.small_headNewTask=render:partial=>'layouts/form_errors',:locals=>{: