草庐IT

update_many

全部标签

ruby-on-rails - Rails ActiveRecord - update_all : how to update multiple fields at once with mixed type of arguments

我有一个用例,我想使用ActiveRecord::Relationupdate_all方法并指定要设置的几个字段。我使用update_all是因为可以更新很多条目,我不想将它们全部加载并一个一个地更新。其中一些需要直接的SQLSET语句,例如因为我根据另一列的值设置一列。是否有一个简单的语法与update_all一起使它可读,沿着这个=>MyModel.where(state::foo).update_all(['timespent=timespent+500',#Can'tbeanythingelsethanaSQLstatementstate::bar,#RegularRailsS

ruby-on-rails - Rails has_many :through --> Should I keep a primary key column?

我有'author'和'book'表,加入了has_many:through表'author_book'据我所知,“author_book”表上的:id主键字段没有任何意义……但在我提出这个想法之前,我只是想确认一下。那么,是否有任何理由将“id”列保留在has_many:through表中?提前致谢... 最佳答案 保留它。稍后您会发现唯一标识符以最初并不明显的方式得到返回。与其他敏捷开发原则不同,最好预先解决此类数据质量问题。 关于ruby-on-rails-Railshas_man

ruby-on-rails - 如何获取具有 min has_many 记录的记录(加入数据)

用户.rbhas_many:properties属性.rbbelongs_to:user我想获得一个具有最小属性的用户,例如wiseformax。我找不到任何相关的查询 最佳答案 要找到具有min属性的用户,您可以简单地做,User.joins(:properties).group("properties.user_id").order("count(properties.user_id)desc").last并找到具有max属性的用户,User.joins(:properties).group("properties.user_i

ruby-on-rails - 如何在 Rails ActiveRecord 中正确分配 has_many/belongs_to 关系?

我有一个带有文章和作者模型的Rails应用程序。如果我有一个作者和一个帖子,并且想表明作者应该是文章的所有者,或者文章属于作者,那么这样做的最佳做法是什么?特别是:如果我设置了会有什么不同my_article.author_id=author_one.id或者如果我这样做author_one使用的关联是作者有_多篇文章文章属于作者另外,如果出现类似问题,最好的查找方式是什么? 最佳答案 以下3个没有区别:my_article.author_id=author_one.idmy_article.save#sameasmy_articl

ruby-on-rails - Rails,has_many :through, 未定义方法 `to_sym` 为 nil:NilClass

我一直在学习Rails,但在关系方面遇到了一个问题。我有多对多关联用户-锦标赛,由于某种原因,我无法访问用户实例上的participated_tournaments,或者无法访问锦标赛实例上的参与者。2.0.0-p643:001>Tournament.new.participantsNoMethodError:undefinedmethod`to_sym'fornil:NilClassfrom/home/marcin/.rvm/gems/ruby-2.0.0-p643/gems/activerecord-4.1.8/lib/active_record/reflection.rb:100

ruby-on-rails - Rails 2 到 Rails 3 : using link_to instead of link_to_remote (including remote and update)

我确定这是一个快速简单的答案。我正在将Rails项目从版本2升级到版本3,并根据Rails3更新将link_to_remote的负载替换为link_to。甚至像:这样简单的事情:get_time},:remote=>true,:update=>'current_time'%>好像不行。请求(使用get方法)正常进行,呈现的html是:CheckTimeRoutes.rb条目:get"monitoring/get_time"正如我所说,我确信这对我来说是一个非常明显的问题! 最佳答案 新的link_to:remote=>true不支持

ruby-on-rails - 我如何在 Rails 中测试 belongs_to 和 has_many?

我正在使用rspec并尝试测试我的模型y是否有很多x。我尝试了各种方法,包括遍历方法数组,但似乎无法在网上找到好的方法。那我应该怎么用呢? 最佳答案 无需太多黑客攻击,您就可以使用卓越的gem:http://github.com/carlosbrando/remarkable摘自非凡的文档:describePostdoit{shouldbelong_to(:user)}it{shouldhave_many(:comments)}it{shouldhave_and_belong_to_many(:tags)}end

ruby-on-rails - Ruby on Rails 在保存之前通过关联对象 has_many

在RubyonRails项目中,我试图在将所有内容保存到数据库之前访问ActiveRecord上的关联对象。classPurchase如果我像这样构建我的对象:purchase=Purchase.new(item_ids:[1,2,3])并尝试保存它item_validation方法还没有填充项目集合,所以即使虽然项目已经设置,但它没有机会调用任何项目的check_something方法。是否可以在我的购买模型和关联模型保留之前访问项目集合,以便我可以对它们运行验证?如果我将item_validation方法更改为:defitem_validationpurchase_items.ea

ruby-on-rails - 通过关联获取 has_many 的 ActiveRecord::RecordInvalid 错误;连接表上的验证问题

我有如下三个关联模型:classProduct当我做类似的事情时:doc=user.documents.builddoc.update_attributes(:product_ids=>[1,2])并且description验证失败,然后我得到false和doc上的相应错误。这正是我想要的。但是,如果doc已经存在,例如:doc=user.documents.firstdoc.update_attributes(:product_ids=>[1,2])并且description验证失败,然后我得到一个ActiveRecord::RecordInvalid错误。我很清楚为什么会这样——i

ruby-on-rails - 设置一个 :has_many :through association on a belongs_to association Ruby on Rails

我有三个模型,每个模型都有以下关联:classModel1:model1#willthiswork?isthereanywayaroundthis?endclassModel3:model1#willthiswork?isthereanywayaroundthis?end正如您在评论文本中看到的那样,我已经提到了我需要的内容。 最佳答案 您只需创建访问它的方法classModel2或者,您可以将model3s方法委托(delegate)给model1classModel2:model1end