草庐IT

question-originals-answer-count

全部标签

ruby - Rails 3 Order By Count on has_many :through

我有一个应用程序,我可以在其中列出项目并为每个项目添加标签。模型Items和Tags是这样关联的:classItem:taggingsendclassTagging:taggingsend因此,这种多对多关系允许我为每个Item设置n标签,并且同一个标签可以多次使用。我想列出所有标签,这些标签按与该标签关联的项目数排序。更多使用的标签,首先显示。较少使用,最后。我该怎么做?问候。 最佳答案 Tag.joins(:taggings).select('tags.*,count(tag_id)as"tag_count"').group(:

ruby-on-rails - object.count 返回 0。但是 object.any?返回真。发生了什么?

@card.submissions返回:]>@card.submissions.any?返回true。@card.submissions.count返回0。我要实现的是:if@card.submissions.any?render@card.submissionsend 最佳答案 看起来Submission是一个新记录(因为id是nil)。如果它是新的,它还没有进入数据库。count对数据库进行SQL调用以确定行数,因此正确地返回零。any?返回true,因为集合中有一个对象。如果您尝试@card.submissions.to_a.

ruby-on-rails - ruby rails : question about validates_presence_of

我在基于ActiveRecord的模型中有一个如下所示的关系:belongs_to:foo我的模型应该始终在其中定义foo才能有效。我的问题是,当使用validates_presenceof时,使用哪个是合适的:validates_presence_of:foo或validates_presence_of:foo_id当然,这里假设foo_id是适当的外键,如果您不更改关联键,则默认情况下它是。 最佳答案 第一个:validates_presence_of:foo(尽管我认为第二个也可以)。通常,Ruby验证助手处理模型名称而不是显

sql - Rails SQL COUNT N+1 效率低下

我有一个博客。在我的索引页面上,我拉入了所有博客文章。对于每篇博客文章,我都会计算该文章的评论数。这会导致N+1问题。我的查询如下所示:SELECT"blog_posts".*FROM"blog_posts"WHERE("blog_posts"."published"='t')ORDERBYpublished_atDESCSELECT"users".*FROM"users"WHERE("users"."id"IN(1,2,3))SELECTCOUNT(*)FROM"blog_comments"WHERE("blog_comments".blog_post_id=10)SELECTCOU

ruby-on-rails - Array.count with block 不返回正确答案

我有一个从数据库调用创建的赋值对象数组:@assignments=@player.assignments我想用这个来计算它们:@assignments.count{|x|x.sets==0.0}这应该计算0.0组的作业数。但是,这总是返回@assignments中的对象总数。我查过了@assignments.each{|x|putsx.sets==0.0}并非在所有情况下都返回true。有什么线索吗?编辑>@assignments.map(&:sets)=>[35.0,120.0,0.0,0.0,0.0,0.0,0.0,12.0,75.0,0.0,0.0,0.0,0.0]

ruby-on-rails - 预期 #count 已更改为 1,但未获得 block

我正在测试我的model方法,该方法返回一个Account对象。我正在检查我的表是否插入了一个新的行并且我的模型反射(reflect)了它的计数。下面是我的规范。it"cancreateanaccount"docreate_account=Account.create(account:acc)create_account.shouldchange(Account,:count).by(1);end我得到的错误8)AccountcancreateanaccountFailure/Error:create_account.shouldchange(Account,:count).by(1)

ruby-on-rails - ruby /RoR : calling original method via super()?

在RoR应用程序中,我想在我的一个模型中专门化ActiveRecord的update_attributes()方法,提取一些属性进行特殊处理,并将其余属性传递给原始的update_attributes()方法。详情:classPremise对super.update_attributes(attr)的调用引发错误:undefinedmethod`update_attributes'fortrue:TrueClass...这让我怀疑我真的不了解Ruby中的super关键字。我错过了什么?具体来说,如何调用原始的update_attributes()方法? 最佳

ruby 摩卡 : is there an equivalent to rspec-mocks' #and_call_original?

Rspec-mocks具有expect(some_object).toreceive(:some_method).and_call_original。我可以用Mocha做这个吗?如果可以,怎么做?some_object.expects(:some_method).......什么? 最佳答案 我相当确定没有办法做到这一点。浏览sourcecode,有评论提到完全替换了原来的方法。#Theoriginalimplementationofthemethodisreplacedduringthetestandthenrestoredatt

sql - GROUP BY 和 COUNT 使用 ActiveRecord

引用这个:IsthereanydifferencebetweenGROUPBYandDISTINCTGivenatablethatlookslikethis:name------barrydavebilldavedavebarryjohnThisquery:SELECTname,count(*)AScountFROMtableGROUPBYname;Willproduceoutputlikethis:namecount-------------barry2dave3bill1john1对于ActiveModel使用COUNT执行GROUPBY的正确Rails约定是什么?

ruby - 数组到哈希 : words count

我有一个单词数组,我想得到一个散列,其中键是单词,值是单词计数。有没有比我的更漂亮的方式:result=Hash.new(0)words.each{|word|result[word]+=1}returnresult 最佳答案 您使用的命令式方法可能是Ruby中最快的实现方式。通过一些重构,您可以编写一个单行代码:wf=Hash.new(0).tap{|h|words.each{|word|h[word]+=1}}另一种使用Enumerable#each_with_object的命令式方法:wf=words.each_with_ob