jjzjj

ruby-on-rails - 在具有 enum_attr 的记录上调用 .all 时参数数量错误

MODEL1有一个account_type,所以使用gem'enumerated_attributes',我制作了这样的模型:classMODEL1我不明白的奇怪的事情是,当我像这样查询任意MODEL1的种子时(这是我在ruby​​mine控制台中运行follwing命令时的错误,但在rakedb期间会发生同样的2for1错误:种子):MODEL1.all.sample和MODEL1.all我明白了:DealerLoad(0.3ms)SELECT"MODEL1".*FROM"MODEL1S"ArgumentError:wrongnumberofarguments(2for1)from/

ruby - 使用 Rails 3 从现有表生成模型

使用Rails3.2.2和ruby1.9.3dev和mysql我是ruby​​和rails的新手。我们有一个包含数百个表的现有数据库。我们想试用Rails,看看它是否会对PHP和ZendFramework产生积极的影响。将数据迁移到另一个数据库对我们来说不是一个选择,因为我们目前有几个其他应用程序正在使用这个数据库。我们想将Rails项目“附加”到现有数据库。我努力的部分是从我们现有的数据库生成所有模型。我看到一些较旧的帖子谈论一些自动化技术,包括MagicModelGenerator.虽然其他人谈论没有办法做到这一点,或者您只能手动创建它们。我没有成功使用MagicModelGene

ruby-on-rails - Rails 验证虚拟属性

我这个模型:classBunny每当我提交一个表单来创建这个模型时,我都会收到以下错误:#的未定义方法“number_before_type_cast” 最佳答案 我通过将此方法添加到我的Bunny模型中解决了这个问题:defnumber_before_type_castnumberend我不喜欢它,但我想在有人发布更好的解决方案之前它会起作用。 关于ruby-on-rails-Rails验证虚拟属性,我们在StackOverflow上找到一个类似的问题: h

ruby-on-rails - 如何使用 has_and_belongs_to_many 将新模型与现有模型相关联

我有两个使用has_and_belongs_to_many建立多对多关系的模型。像这样:classCompetition如果我们假设我已经在数据库中创建了多个竞赛,当我创建一个新团队时,我想使用嵌套表单将新团队与任何相关竞赛相关联。正是在这一点上,我确实需要帮助(已经坚持了几个小时!)我认为我现有的代码已经以错误的方式解决了这个问题,但我会展示它以防万一:classTeamsController还有View...这是我真正卡住的地方,所以到目前为止我不会同时发布我的努力。我想要的是每个比赛的复选框列表,以便用户可以只选择适合的比赛,而不选中不适合的比赛。我真的被这个问题困住了,非常感谢

ruby-on-rails - 如何针对组合字段的唯一性对这种复杂的验证进行建模

link有两个组件:componenta_id和componentb_id。为此,在Link模型文件中我有:belongs_to:componenta,class_name:"Component"belongs_to:componentb,class_name:"Component"validates:componenta_id,presence:truevalidates:componentb_id,presence:truevalidates:componenta_id,uniqueness:{scope::componentb_id}validates:componentb_id

sql - 如何模拟ActiveRecord Model.count.to_sql

我想显示一个计数中使用的SQL。但是,Model.count.to_sql将不起作用,因为count返回一个没有to_sql方法的FixNum。我认为最简单的解决方案是这样做:Model.where(nil).to_sql.sub(/SELECT.*FROM/,"SELECTCOUNT(*)FROM")这会创建与Model.count中使用的SQL相同的SQL,但它是否会导致进一步的问题?例如,如果我添加一个复杂的where子句和一些连接。有更好的方法吗? 最佳答案 你可以试试Model.select("count(*)asmode

ruby-on-rails - 在 Model 类方法中指定当前抓取的记录

我有一个类方法,我想在其中修改当前由ActiveRecord::Relation对象抓取的记录。但是我不知道如何在类方法中引用当前范围。self不会这样做。例子:classUser我会这样使用它:User.some_scope.modify_those_records所以User.some_scope会返回给我一个ActiveRecord::Relation,其中包含一堆User记录。然后我想在该类方法中修改这些记录,然后返回它们。问题是:我不知道如何在类方法中明确引用“那组记录”。 最佳答案 您可以使用current_scope:

ruby-on-rails - 覆盖gem中的模型,添加回调和方法

我已经在我的应用程序上安装了ActiveRecord信誉系统。我将如何覆盖或添加回调/方法到Evaluation模型?一般来说,您如何为您安装的gem添加到任何模型? 最佳答案 只需重新打开类(class):moduleReputationSystemclassEvaluation你可以把这个文件放在config/initializers/my_monkey_patch.rb或在lib/my_monkey_patch.rb,但后者必须加载到您的代码中。 关于ruby-on-rails-覆

ruby-on-rails - rails : Do I need a controller for each model?

关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭9年前。Improvethisquestion我有一个包含4个模型的Rails应用程序。我只在一个Controller操作中访问这4个模型。我目前有4个不同的Controller来处理这些模型。我想知道将这4个Action塞入一个Controller是否是一种不好的做法。当前设置:classGmDataController建议的设置:classDashboardController

ruby-on-rails - rails : call method within model

这个我想不通。在Rails模型中,我想在同一模型中调用一个方法来操作find方法返回的数据。这个“过滤器”方法将从这个模型中的许多自定义查找方法中调用,所以我希望它是分开的。(而且我无法从SQL中过滤它太复杂了)这是一个例子:#controller@data=Model.find_current#modelclassModeldefself.find_current@rows=find(:all)filter_my_rowsreturn@rowsenddeffilter_my_rows#dostuffhereon@rowsforrowin@rows#basicallyIremovero