草庐IT

ActiveRecord

全部标签

ruby-on-rails - 如何在 Rails 3 的表格列中找到最小值

嗨,假设我有一个table(ads),其中有一个column(views)观看次数21463如何找到该列中的最小值?有什么简单的方法可以做到这一点?这就是我的@ads=Ad.all@show_this_ad=@ads.min(:views)这给了我一个“参数数量错误(1代表0)错误”@ads=Ad.all@show_this_ad=@ads.minimum(:views)这给了我一个“未定义的方法错误” 最佳答案 Ad.minimum(:views)应该可以您仍然可以添加更多限制,例如:Ad.where(:user_id=>1234

ruby-on-rails - 如何在 Rails 模型中添加日期属性

您好,我是RoR的初学者,在生成特定模型时遇到了一些麻烦。我想创建2个模型-列表和项目。该列表有_许多项目和项目属于_列表。我希望Item模型具有3个属性。railsgmodelItemname:stringdesc:stringdate:????1.为date:???添加什么数据类型2.日期属性的格式是什么?(mm/dd/yy)?3.它应该有什么样的表单输入?f.date_field:date?提前致谢! 最佳答案 1。要为date:???添加什么数据类型在您的迁移中,您可以使用以下类型的列::string,:text,:inte

ruby - 在不保存的情况下运行 ActiveRecord 验证

我有一组ActiveRecord对象。我希望能够为这些对象中的每一个运行所有验证,而无需将它们实际保存到数据库中。我只想知道如果我将它们保存到数据库中它们是否有效。换句话说,我基本上想为我的每个对象填充errors数据结构。有没有办法做到这一点?或者我可能遗漏了一些关于errors集合的生命周期的信息? 最佳答案 您可以执行以下操作来检查模型是否有效:@user=User.newif@user.valid?#dothings如果你想看看错误是什么,你可以这样做:@user=User.newunless@user.valid?@use

ruby-on-rails - Rails 3. 按关联模型排序

假设我有两个模型:Course和ScheduledCourse。类(class)模型有一个名称属性。coursehas_many:预定类(class)scheduled_courses:属于类(class)coursesid|name1|biology2|history3|chemistry4|literaturescheduled_coursesid|course_id1|22|43|14|2如何进行ActiveRecord查询以按字母顺序对安排的类(class)进行排序? 最佳答案 尝试...ScheduledCourse.jo

ruby-on-rails - ActiveModel 方法属性 "_was"的用途是什么?

在控制台中使用自动完成功能时,我经常看到“_was”附加到我的属性中。但是我找不到任何文档或使用的最佳实践。它有什么作用,应该如何使用?示例:user.fname具有方法user.fname_was使用source_location,我将其追踪到:active_model/attribute_methods.rb",第296行,但没有任何具体信息。 最佳答案 那是ActiveModel::Dirty的一部分你可以在这里看到它https://github.com/rails/rails/blob/af64ac4e5ce8406137d

ruby-on-rails - 如何在 Ruby on rails 中按余额对项目进行排名

我正在实现一个投注系统,每个用户都有余额,我如何使用activerecord方法找到用户的排名?感谢您的帮助。 最佳答案 获取用户排名,Users.all(:order=>"balance").index(a_particular_user)这应该为您提供所有用户数组中特定用户的索引(等级)(按余额排序)。 关于ruby-on-rails-如何在Rubyonrails中按余额对项目进行排名,我们在StackOverflow上找到一个类似的问题: https:/

ruby-on-rails - 如何在 Rails 3 中为 DATETIME 列保存当前日期/时间?

我有一个名为last_profile_update的DATETIME列。我需要用当前时间更新它。我有以下代码:user=User.newuser.last_profile_update=Date.todayuser.save但它不起作用。 最佳答案 也许是一种简化该代码的方法:user=User.create(:last_profile_update=>Time.now) 关于ruby-on-rails-如何在Rails3中为DATETIME列保存当前日期/时间?,我们在StackOve

sql - Ruby on Rails 迁移中的 unsigned int 字段?

我怎样才能使populationunsigned?defself.upcreate_table:citiesdo|t|t.string:namet.integer:populationt.float:latitudet.float:longitudet.timestampsendend 最佳答案 这应该适合你。t.column:population,'integerunsigned' 关于sql-RubyonRails迁移中的unsignedint字段?,我们在StackOverflow

ruby-on-rails - 为 rails 中的所有记录批量缩减一个字段

当我第一次实现用户模型时,我允许用户输入大写或小写的电子邮件作为他们的登录信息。问题是它是一个移动应用程序,有时会发生自动上限,因此用户无法通过身份验证。我已经更改了CREATE方法以首先将电子邮件小写。但是,这会导致现有帐户的人不一致那么如何添加一个迁移来批量更新用户表中的电子邮件字段以将其小写? 最佳答案 最有效的方法是避免使用Ruby迭代器,而是直接在SQL中执行。在正常的迁移文件中,您可以将此SQL用于MySQL:execute("UPDATEusersSETemail=LOWER(email)")

ruby-on-rails - 如何将枚举作为字符串存储到 Rails 中的数据库

我如何在默认为字符串而不是整数的ruby​​中创建迁移,我想将枚举存储到数据库中,但我不想将其存储为整数,因为这样就没有意义了另一个想要使用同一张表的应用程序。我该怎么做default:"female"而不是default:0classAddSexToUsers我 最佳答案 阅读enum文档中,您可以看到Rails使用Array的值索引解释为:NotethatwhenanArrayisused,theimplicitmappingfromthevaluestodatabaseintegersisderivedfromtheorder