草庐IT

AI 模型

全部标签

ruby-on-rails - 在 Rails 模型中动态生成范围

我想动态生成作用域。假设我有以下模型:classProduct我们可以用基于POSSIBLE_SIZES常量的东西替换scope调用吗?我认为我违反了DRY以重复它们。 最佳答案 你可以做classProduct但我个人更喜欢:classProduct 关于ruby-on-rails-在Rails模型中动态生成范围,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/14061595/

ruby - 覆盖 Mongoid 模型的 setter 和 getter

有没有办法在Mongoid中覆盖模型的setter或getter?像这样的东西:classProjectincludeMongoid::Documentfield:name,:type=>Stringfield:num_users,type:Integer,default:0key:namehas_and_belongs_to_many:users,class_name:"User",inverse_of::projects#Thiswillnotworkdefname=(projectname)@name=projectname.capitalizeendendname方法可以在不使

ruby-on-rails - 带有字符串输入的引用模型

假设我希望创建一个页面,该页面可以使用type(string)和id(int)查询所需的对象。/query?type=people&id=1会接我Person.find(1)鉴于/query?type=cities&id=123会接我City.find(123)但是,关于如何将字符串转换为所需的模型类,我遇到了问题。我能想到的唯一办法是caseparams[:type]when'people'@object=Person.find(params[:id])when'cities'@object=City.find(params[:id])end但是,如果我有更多类型的模型,这种方法就会

ruby-on-rails - rails 模型的默认值

迁移时设置默认值好还是回调时设置默认值好?很难在迁移中删除(或设置另一个)默认值,但在模型中它多了一段代码 最佳答案 在迁移中定义默认值也有一些缺点。当您只调用Model.new时,这将不起作用。我更喜欢写after_initialize回调,它让我设置默认属性:classModel 关于ruby-on-rails-rails模型的默认值,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questio

ruby-on-rails - 如何从 YAML 文件加载一些 ActiveRecord 模型并将它们保存到数据库?

我正在尝试将一些查找表数据保存到YAML文件中,以便稍后当我需要在另一台机器上设置我的应用程序时,我可以将数据作为种子数据加载。数据是选择选项之类的东西,而且几乎已经设置好,所以不用担心序列化和反序列化之间的实时数据变化。我已经输出了这样的数据......file=File.open("#{RAILS_ROOT}/lib/tasks/questions/questions.yml",'w')questions=Question.find(:all,:order=>'order_position')file我可以像这样加载文件...questions=YAML.load_file('li

ruby-on-rails - 在rails 4中设计用户模型中保存自定义字段

我设计了一个用户模型并向其添加了额外的字段。当我创建和帐户时,一切正常,只有电子邮件、pw和pwconf。然后我想让用户进入编辑页面并填写可选的附加字段。但是,当他们提交时,所有内容都保存为nil。classRegistrationsControllertruerespond_withresource,:location=>after_update_path_for(resource)elseclean_up_passwordsresourcerespond_withresourceendenddefuser_paramsparams.require(:user).permit(:em

ruby-on-rails - 将 PG::Result 转换为 Active Record 模型

pg-ruby允许您一次性向数据库发送多个查询,这有助于最大限度地减少访问数据库的次数:results=[]conn.send_query('QUERY1;QUERY2;QUERY3')conn.blockwhileresult=conn.get_resultresults假设对于任何result我已经知道ActiveRecord模型,将结果转换为模型的合适方法是什么?现在我正在做以下事情:fields=result.fieldsmodels=result.values.map{|value_set|Model.new(Hash[fields.zip(value_set)])}该方法的

ruby-on-rails - 工厂女孩在构建/创建时将参数传递给模型定义

模型/message.rbclassMessageattr_reader:bundle_id,:order_id,:order_number,:eventdefinitialize(message)hash=message@bundle_id=hash[:payload][:bundle_id]@order_id=hash[:payload][:order_id]@order_number=hash[:payload][:order_number]@event=hash[:concern]endend规范/模型/message_spec.rbrequire'spec_helper'de

ruby-on-rails - 我的非模型/非 Controller 代码应该放在哪里?

我编写了一个遵循常规目录结构的Rails应用程序(模型代码在模型中,Controller代码在Controller中)。但我现在正在开发一项新功能,为此我编写了一些(我称之为)“服务”代码。新功能是将一些数据导入系统,目前是两个类来进行导入,但可以扩展到更多。我不认为新代码属于模型,因为它不对任何对象建模(它也不直接与任何单个对象相关。我当然不认为它属于Controller,因为它不是表示逻辑。因此,我创建了一个“app/services”目录并将其放在那里。我还创建了一个“test/services”目录,用于放置我的测试。我认为一切都很好,但是当我运行“rake:test”或“au

ruby-on-rails - 如何将本地文件上传到 Carrierwave 模型?

我使用Carrierwave来处理图像上传,但我没有使用表单,而是使用服务器中的本地文件。我怎样才能让它工作?@user=User.firstimage_path="/tmp/pic-s7b28.jpg"@user.image=image_path@user.save! 最佳答案 @user=User.firstimage_path="/tmp/pic-s7b28.jpg"@user.image=File.open(image_path)@user.save!您可以查看carrierwavereadme中的示例