草庐IT

has_is_baz

全部标签

ruby-on-rails - rails : has_many through not returning correctly with namespaced models

我有3个模型。Rom::Favorite,Rom::Card,User。我在创建Userhas_manyrom_cardsthroughrom_favorites时遇到问题这是我模型的相关部分Rom::CardclassRom::Card用户classUserRom::收藏classRom::Favorite{:scope=>:user_id}self.table_name="rom_favorites"end除了之外,关联的所有实用方法都有效a=User.find(1)a.rom_cards调用a.rom_cards返回一个空数组,它似乎运行了这个SQL查询SELECT"rom_fa

ruby - main :Object (NoMethodError) though method is defined 的未定义方法

我已经使用以下代码片段定义了一个脚本:check_paramsparamdefcheck_params(param)#somecodeend当我运行它时,我得到了undefinedmethod`check_params'formain:Object(NoMethodError) 最佳答案 Ruby期望方法在你调用它之前被声明,尝试在你调用方法之前移动你的方法定义:defcheck_params(param)#somecodeendcheck_paramsparam 关于ruby-main

ruby - Aptana 3 ruby​​ 调试器 - DebugThread 循环中的异常 : undefined method `is_binary_data?'

我正在尝试在Aptana3中调试简单的ruby​​文件。classHelloWorlddefinitialize()enddefgreet()puts"helloworld"endendh=HelloWorld.newh.greet断点设置为h.greet在我开始调试后,调试器启动,但是当它尝试初始化ruby​​类时,调试器断开连接并显示消息FastDebugger(ruby-debug-ide0.4.9)listenson:54749ExceptioninDebugThreadloop:undefinedmethod`is_binary_data?'for"#":String当我将断

ruby-on-rails - 在 Rails 3 中将现有的 has_many 关系更改为多态

我在两个模型之间有一个现有的has_many关系-称它们为“汽车”和“乘客”-在我的生产环境中有几千个“乘客”属于几百个“卡片”。我正在添加另一个模型,称之为“火车”,我想将汽车和乘客之间现有的has_many关系更改为多态关系,将每位乘客与汽车或火车相关联。我的迁移应该是什么样的?我想在迁移时保留数据库中的现有关系,所以我宁愿进行一些表重命名,而不是删除一列以将其替换为另一列。此外,我希望能够在不打开服务器控制台并手动编辑所有记录的情况下执行此操作,这样当我将更改推送到生产环境时,我可以一次性迁移整个数据库。有什么建议吗?TL;DR:如何使用新模型将现有的has_many关系更改为多

ruby-on-rails - :autosave property of has_many associations broken in Rails 2. 3.4?

在我将此作为错误发布给Rails团队之前,我想看看我是否做错了可能导致此行为的事情。具体来说,has_many关联的:autosave属性似乎没有按照文档工作。作为引用,这里是最新的API文档:http://api.rubyonrails.org/classes/Acti...ation.html查看“一对多示例”部分。我已经在测试应用程序中完全复制了代码,但它对我不起作用。具体来说,更新父对象,但不更新子对象。我的架构如下:create_table:postsdo|t|t.string:titlet.timestampsendcreate_table:commentsdo|t|t.t

ruby-on-rails - 使用 FactoryGirl 验证 has_many 关联至少有一个模型

抛开关于是否应该测试模型关联是否存在的争论,我有一个名为Order的模型,我正在验证它至少有一个item在其has_many关联中使用:classOrder我已将FactoryGirl设置为检查我的工厂(检查有效性)。所以我的订单工厂是无效的,除非我为其has_many集合创建一个项目。我的订单工厂看起来像这样:FactoryGirl.definedofactory:orderdoignoredoitems_count1endafter(:build)do|order,evaluator|create_list(:item,evaluator.items_count,order:ord

ruby-on-rails - 对于新的 ActiveRecord 模型,为什么有些 has_many :through associations add a (1=0) predicate and distinct clause to the sql query?

每当我实例化一个新的ActiveRecord模型(一个尚未持久化到数据库中的模型)并尝试访问构建模型上的一些各种关联时,Rails查询构建器有时会:将(1=0)谓词添加到查询的where子句。在select语句中添加“distinct”子句。我认为这只会在has_many:through关联连接两个或多个表时发生。我想知道为什么它添加了(1=0)谓词以及distinct子句。对于(1=0)谓词,新模型是否已保存到数据库应该无关紧要(对吧?)。我不知道为什么要添加distinct子句。我在下面有一个简单的例子。classAssignment#s.assignment_attachment

ruby-on-rails - 为 has_many :through relationship in Rails 3 创建 Controller 和 View

有很多教程向您展示如何在Rails中为has_many:through关系创建模型指令,但似乎没有很多文章与设置表单以创建和编辑这些关系的过程相关。我正在寻求一些帮助(或很好的例子)来了解如何创建一个允许用户在Rails应用程序中管理这些类型的关系的界面。场景如下:IhaveUsers,Relationships,andAthletes.AUsercanhaveaRelationshipwithanAthleteinavarietyofroles:Coach,Mentor,Parent,orFan.这是我的模型:classUser:relationshipsendclassAthlet

ruby-on-rails - Rails 国际化 : %{record} is not being translated

我的rails.pt-BR.yml上有这个:br:errors:format:!'%{attribute}%{message}'messages:restrict_dependent_destroy:one:"Nãoépossívelexcluiroregistropoisexisteum%{record}dependente"many:"Nãoépossívelexcluiroregistropoisexistem%{record}dependentes"在我的模型中,我有这个:has_many:entities,dependent::restrict_with_error每当res

sql - has_many :through 的索引

假设您有两个模型,User和City,由第三个模型CityPermission加入:classCityPermission:city_permissionsendclassUser:city_permissionsend目前,我使用以下迁移代码片段创建连接表和表索引:create_table:city_permissionsdo|t|t.integer:user_id,:city_idt.other_fields...endadd_index(:city_permissions,:user_id)add_index(:city_permissions,:city_id)这些是要创建的最