草庐IT

Activerecord

全部标签

ruby-on-rails - rails : HasManyThroughAssociationNotFoundError

我在使用has_manythrough关联时遇到问题。我一直收到这个异常:Article.find(1).warehouses.buildActiveRecord::HasManyThroughAssociationNotFoundError:Couldnotfindtheassociation:entriesinmodelArticle这些是涉及的模型:classArticle:entriesendclassWarehouse:entriesendclassEntry这是我的模式:create_table"articles",:force=>truedo|t|t.string"art

ruby-on-rails - 什么是 Post.all.map(& :id) mean?

这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:Whatdoesmap(&:name)meaninRuby?Post.all.map(&:id)会回来=>[1,2,3,4,5,6,7,................]map(&:id)是什么意思?特别是&。

ruby-on-rails - 我如何在具有事件记录的 Rails 中使用两个不同的数据库?

我需要在不同的Rails模型中使用不同的数据库连接。有没有一种不太hacky的方法来做到这一点?任何链接或搜索关键字都很棒:) 最佳答案 将新部分添加到您的database.yml例如other_development:adapter:mysqldatabase:otherdb_developmentusername:rootpassword:host:localhostother_production:adapter:mysqldatabase:otherdb_productionusername:rootpassword:hos

ruby-on-rails - 何时(如果)合并 ActiveRecord 迁移?

当我在我的应用程序*(s)上进行迭代时,我积累了迁移。截至目前,共有48个此类文件,跨越大约24个月的事件。我正在考虑采用我当前的schema.rb并将其作为基线。我也在考虑删除(当然,受源代码控制)现有的迁移并从我当前的模式创建一个漂亮的Shiny的新单一迁移?迁移倾向于使用符号,但rakedb:schema:dump使用字符串:我应该关心吗?这看起来合理吗?如果是这样,在什么样的时间间隔进行这样的练习才有意义?如果不是,为什么不呢?我是否错过了一些(佣金?)可以为我完成的任务?*在我的例子中,所有应用程序都是基于Rails的,但是任何使用ActiveRecord迁移的应用程序似乎都

ruby - hash ['key' ] 到 Ruby 中的 hash.key

我有一个散列foo={'bar'=>'baz'}我想调用foo.bar#=>'baz'我的动机是将activerecord查询重写为原始sql查询(使用Model#find_by_sql)。这将返回以SELECT子句值作为键的散列。但是,我现有的代码依赖于object.method点表示法。我想做最少的代码重写。谢谢。编辑:看来Lua有这个功能:point={x=10,y=20}--Createnewtableprint(point["x"])--Prints10print(point.x)--Hasexactlythesamemeaningaslineabove

ruby-on-rails - 为什么不为 Rspec + Selenium 使用共享的 ActiveRecord 连接?

处理Selenium和测试的最普遍接受的方法似乎是避免使用事务固定装置,然后在测试/场景之间使用database_cleaner之类的东西。我最近遇到了以下article建议执行以下操作:spec_helper.rbclassActiveRecord::Basemattr_accessor:shared_connection@@shared_connection=nildefself.connection@@shared_connection||retrieve_connectionendend#Forcesallthreadstosharethesameconnection.This

ruby - 为什么在 ruby​​/rails/activerecord 中并不总是需要 self?

在Rails模型中测试getter/setter对时,我发现了一个很好的行为示例,我一直认为这种行为很奇怪且不一致。在这个例子中,我处理的是classFolder.Folderbelongs_to:parent,:class_name=>'Folder'在getter方法上,如果我使用:defparent_nameparent.nameend……或者……defparent_nameself.parent.nameend...结果完全一样,我得到了父文件夹的名称。但是,在getter方法中,如果我使用...defparent_name=(name)parent=self.class.fi

ruby-on-rails - Rails 可选的 belongs_to

我正在编写用于库存管理的Rails前端。我希望用户能够注册产品,所以我有:classUserend和classProductend问题在于产品是在用户注册之前创建的。也就是说,调用Product.create并将user_id设置为nil是完全可以接受的。不过,您可以想象,Rails不支持开箱即用:>Product.create!(0.3ms)SELECTCOUNT(*)FROM"products"WHERE"products"."type"IN('Product')(0.1ms)begintransaction(0.1ms)rollbacktransactionActiveRecor

ruby-on-rails - ActiveModel::MissingAttributeError 在部署后发生,然后在一段时间后消失

我有一个Rails3.0.9应用程序,一旦部署,就会遇到一堆ActiveModel::MissingAttributeErrors,这些错误会突然出现并导致500秒。错误相当随机地发生,有时页面会加载,有时不会,但属性都是数据库中的现有属性,应该可以找到。奇怪的是,一段时间后,错误消失了。突然之间,它们不再引起问题。我已经搜索过这个问题的解决方案,但这个错误主要发生在有人完成Model.all(:select=>'column_x,column_y')并调用column_z或者当他们使用cache_money时。这些我都没有做。有人能帮忙吗? 最佳答案

ruby-on-rails - ActiveRecord 如何忽略挂起的迁移

问题如下:我有包含初始数据的db/seed.rb。其中一个迁移取决于该种子提供的数据。我正在尝试从空数据库部署我的应用程序。结果是:RAILS_ENV=productionrakedb:migrate-由于缺少初始数据而失败RAILS_ENV=productionrakedb:seed-由于未决迁移而失败我想以某种方式告诉rake忽略挂起的迁移,但到目前为止无法做到。更新(由于额外的经验)有时迁移和模型代码不同步,因此迁移不会运行。为了避免这个问题,最近在迁移中使用了模型的重新定义:#resetallcallbacks,hooks,etcforthismodelclassMyAweso