我有一个@bunch模型作为数组返回每个模型都有属性-commentable_id和commentable_type(多态关联)我想按可评论的方式对模型进行分组,但如果这样做的话@bunch.group_by(&:commentable)它还会从数据库中获取可评论的内容,这是不需要的。我可以做@bunch.group_by(&:commentable_id)但这会引起一些混淆,因为可能有几种类型的可评论模型有没有办法group_bycommentable_idANDcommentable_type? 最佳答案 为什么不这样做:@bu
我的用户表登录列是String类型,限制为40个字符。现在我打算将限制增加到55个字符。任何人请让我知道我们如何通过使用ROR迁移来增加此限制。谢谢,沙湾 最佳答案 classYourMigration55enddefdownchange_column:users,:login,:string,:limit=>40endend 关于ruby-on-rails-rails迁移:HowtoincreasecolumndatatypesizebyusingRORmigration,我们在Sta
ActionView::Template::Error(PG::Error:ERROR:forSELECTDISTINCT,ORDERBYexpressionsmustappearinselectlist我正在创建一个事件网站,我正在尝试按事件的开始时间对呈现的rsvps进行排序。有很多RSVPS,所以我将它们分组为不同的,但在过去的几天里,我在排序结果时遇到了很多困难,而没有在PG上弹出这个错误。我已经查看了之前关于该主题的一些问题,但仍然很迷茫。我怎样才能让它工作?非常感谢!@rsvps=Rsvp.where(:voter_id=>current_user.following.co
在Rails中,find_each和where用于从ActiveRecord支持的数据库中检索数据。您可以将查询条件传递给where,例如:c=Category.where(:name=>'Ruby',:position=>1)并且您可以将批量大小传递给find_each,例如:Hedgehog.find_each(batch_size:50).map{|p|p.to_json}但是下面两段代码有什么区别呢?#code1Person.where("age>21").find_each(batch_size:50)do|person|#processingend#code2Person.
我觉得这应该很简单,但是我的脑子短路了。如果我有一个代表当前用户的对象,并且想查询除当前用户之外的所有用户,考虑到当前用户有时可能为nil,我该怎么做?这就是我现在正在做的:defindex@users=User.all@users.deletecurrent_userend我不喜欢的是我正在对查询结果进行后处理。除了感觉有点不对之外,如果我将查询转换为使用will_paginate运行,我认为这不会很好地工作。关于如何通过查询执行此操作的任何建议?谢谢。 最佳答案 可以在Rails4及更高版本中执行以下操作:User.where.
一段时间以来我一直在尝试安装这个“rubygame”gem,但是每当我使用命令时geminstallrubygame会报错:ERROR:Couldnotfindavalidgem'rubygame'(>=0)inanyrepositoryERROR:Whileexecutinggem...(Gem::RemoteFetcher::FetchError)Errno::ETIMEDOUT:Connectiontimedout-connect(2)(http://rubygems.org/latest_specs.4.8.gz)我也尝试过其他gems但结果相似:ERROR:Couldnotf
Ruby和Rails的新手,但我现在已经受过书本教育(这显然没有任何意义,哈哈)。我有两个模型,Event和User通过表EventUser连接classUser:event_usersendclassEventUser:event_usersend这个项目是一个日历,我必须在其中跟踪人们为给定的事件注册和刮掉他们的名字。我认为多对多是一种好方法,但我不能这样做:u=User.find:firstactive_events=u.events.find_by_active(true)因为事件实际上没有额外的数据,所以EventUser模型有。虽然我可以做到:u=User.find:fir
在我当前的Rails程序中,当我使用类似的东西时user=User.find(10)当没有ID=10的用户时,我会有如下异常:ActiveRecord::RecordNotFound:Couldn'tfindUserwithID=10我可以得到nil而不是引发异常吗,所以当我做类似的事情时:unlessuser=Challenge.find(10)puts"someerrormsg"end我只想在没有记录的时候得到nil,我不想使用begin/rescue谢谢 最佳答案 是的,只是做:Challenge.find_by_id(10)
当您在Rails中执行Something.find(array_of_ids)时,结果数组的顺序不取决于array_of_ids的顺序。有什么办法可以找到并保留顺序吗?ATM我根据ID的顺序手动对记录进行排序,但这有点蹩脚。UPD:如果可以使用:order参数和某种SQL子句指定顺序,那么如何? 最佳答案 奇怪的是,没有人提出这样的建议:index=Something.find(array_of_ids).group_by(&:id)array_of_ids.map{|i|index[i].first}除了让SQL后端执行它之外,尽
当我尝试执行bundlerupdate时出现此错误:.rvm/rubies/ruby-1.9.2-p180/lib/ruby/site_ruby/1.9.1/rubygems/dependency.rb:247:in`to_specs':Couldnotfindbundler(>=0)amongst[rake-0.8.7,rake-0.8.7,rubygems-update-1.8.4](Gem::LoadError)我是Ruby的新手,有人能告诉我这是什么原因吗?安装了Rake0.8.7。 最佳答案 如果您安装了bundlerge