草庐IT

ActiveRecord

全部标签

ruby-on-rails - ActiveRecord 关联选择包含记录的计数

例子classUserhas_many:ticketsend我想创建关联,其中包含用户计数票的逻辑,并在包含(用户has_oneticket_count)中使用它Users.includes(:tickets_count)我试过了has_one:tickets_count,:select=>"COUNT(*)astickets_count,tickets.user_id",:class_name=>'Ticket',:group=>"tickets.user_id",:readonly=>trueUser.includes(:tickets_count)ArgumentError:Un

ruby - 如何在 Rails 之外的 Ruby 项目上加载 ActiveRecord 数据库任务?

事件记录3.2.14我想在非RailsRuby项目中使用ActiveRecord。我想让ActiveRecord定义的rake任务可用。我该怎么做?rakedb:create#CreatethedatabasefromDATABASE_URLorconfig/database.ymlforthecurrentRails.env(usedb:create:alltocreatealldbsintheconfig)rakedb:drop#DropsthedatabaseusingDATABASE_URLorthecurrentRails.env(usedb:drop:alltodropal

ruby-on-rails - 查找所有具有重复名称的用户

我的用户有first_name和last_name字段,我需要做一个ruby​​根据名字和姓氏找到所有有重复帐户的用户。例如,我想找到一个可以搜索所有其他用户并查找是否有相同姓名和电子邮件的人。我在想这样的嵌套循环User.all.eachdo|user|//maybeanotherlooptosearchthroughalltheusersandmaybeifamatchoccursputthatuserinanarrayend有没有更好的办法 最佳答案 您可以通过首先找出重复数据的内容来大大缩小搜索范围。例如,假设您要查找多次使

ruby-on-rails - 类似 Twitter 关注者/在 ActiveRecord 中关注的关系

我试图在我的应用程序中表示用户之间的关系,其中一个用户可以有很多关注者并且可以关注其他用户。我想要像user.followers()和user.followed_by()这样的东西你能详细告诉我如何使用ActiveRecord表示这个吗?谢谢。 最佳答案 你需要两个模型,一个Person和一个FollowingsrailsgeneratemodelPersonname:stringrailsgeneratemodelFollowingsperson_id:integerfollower_id:integerblocked:boole

ruby-on-rails - rails : validating a field is present only if another is present

我有一个模型,其中有两个字段在技术上可以为空。字段名称是:is_activated和:activated_at。:activated_at仅在:is_activated设置为true时才需要。如果:is_activated为false,则不需要存在。在Rails中将此验证直接设置到ActiveRecord中的合适方法是什么? 最佳答案 您可以使用Proc在:activated_at验证器上。validates:activated_at,:presence,if:Proc.new{|a|a.is_activated?}推荐阅读:htt

ruby - ActiveRecord - 获取最后 n 条记录并在一个命令中删除它们?

大家好,感谢您花时间回答我的问题。题中确实解释了这个问题。我尝试了Model.last(n).destroy_all但都不起作用。我想知道是否可以在一行中完成,如果不能,最简洁的方法是什么?再次感谢! 最佳答案 要在一个SQL查询中执行此操作,请使用delete_all:Model.order(created_at::desc).limit(n).delete_all但是delete_all不会执行任何模型回调或验证要运行回调和验证,请使用destroy_all:Model.order(created_at::desc).limit

ruby-on-rails - 如何覆盖 Rails 模型中的列?

我有一个数据库表的模型。我想覆盖该特定表的列名。我将如何实现它。例如,假设我的表名为DUMMY,其中有一列名为col_acol_a2034422312我会做一个@dummy.col_a。现在,对于以0结尾的数字,此方法应返回0,对于其他所有内容,它应返回原始值。我可以通过定义一个新方法来做到这一点,但我想覆盖列名本身。请帮忙。 最佳答案 您可以覆盖col_a方法。使用read_attribute方法读取数据库中的值。像这样:defcol_aifself.read_attribute(:col_a).to_s.end_with?('0

ruby-on-rails - Rails 3. 如何对所有记录执行保存操作?

我有一个名为shipments的模型。我在shipments表中添加了一些列,并且有一些列应该在保存之前计算。所以现在我必须编辑每条记录并点击更新,以便新列计算和添加数据。那么有没有办法对所有出货记录进行全局保存,以便添加数据?before_save:default_valuesdefdefault_valuesself.volume=1unlessself.volumeself.kilograms=1unlessself.kilogramsself.status="Open"ifself.status.blank?ifself.mode=="Air"self.estimated_tr

ruby-on-rails - 如何在没有 Rails 的情况下使用事件记录

伙计们我试图在没有rails的情况下使用事件记录,但似乎无法让has_many正常工作。我从未尝试过在没有Rails的情况下使用事件记录。我可以从单个表中查询,但关系似乎不起作用。任何人都可以快速浏览一下,看看我是否遗漏了什么。这是stub#!/usr/bin/rubyrequire'rubygems'gem'activerecord'require'sqlite3'require'active_record'ActiveRecord::Base.establish_connection(:adapter=>'sqlite3',:database=>'test.db')classUse

ruby - 哪个查询去了哪个数据库的 ActiveRecord 日志

在与不同数据库有多个连接的ActiveRecord应用程序中,日志中没有任何内容表明哪个查询去了哪个数据库。这些查询分离数据库:Base1.connection.select_value("select*fromfoo")Base2.connection.select_value("select*fromfoo")发出这些日志条目:D,[2017-03-13T09:27:11.844395#22112]DEBUG--:(0.6ms)select*fromfooD,[2017-03-13T09:27:11.844539#22112]DEBUG--:(0.1ms)select*fromfo