我的要求是得到不同的记录并按顺序User.joins('INNERJOINreport_postsONposts.id=report_posts.post_id').select('DISTINCTON(report_posts.post_id)posts.idasreport_posts.idasreported_id,report_posts.reported_at').order('report_posts.reported_atdesc')我知道这在postgresql中是不可能的,我已经读过这个PostgresqlDISTINCTONwithdifferentORDERBY我
我有一个参数,就像params[:time_range]一样。在我的Controller中,我想使用这个时间范围参数在我的查询中指定一个特定范围,如下所示:#params[:time_range]="week"time=params[:time_range]query=Article.where(created_at:1.#{time}.ago)当然它不能像现在这样工作。有没有办法将params[:time_range]字符串转换成月、日、周类型?我尝试使用to_sym但那个week不是符号。当我尝试用1.week找到它的类时,我得到了Fixnum。有谁知道解决这个问题的方法吗?
您好,我已经搜索过了,但还没有找到执行此操作的方法我有以下模型:classHierarchy.classFamily:hierarchiesend.classUser:hierarchiesend有了current_user,我需要获取他的所有其他家庭成员,按级别分组,然后按列顺序排序。我会说出我尝试过的,但实际上并没有那么多,而且这个查询超出了我的能力范围。我正在使用postgres。 最佳答案 我会采用以下方法..我们必须更新用户模型:)classUser:hierarchieshas_many:family_members,-
我有两个模型:User和Message,它们通过has_many关系连接。我想获得一个users列表,按他们上一条消息的时间戳排序。classUser当我这样做时:@users=User.includes(:messages).order('messages.created_atDESC').limit(5)它似乎对消息进行排序,获取最新的5条消息,然后返回与这些消息关联的用户。所以用户数可以少于5个。我想确保获得5个用户。我希望查询为每个请求获取最新消息,对最后的消息进行排序,然后将最新消息返回给用户。所以我想要这样的东西:@users=User.includes(:messages
我正在开发一个Rails3.2ruby1.9.2项目。我从经典数据库中获取了一些值:designators=Model.find()我用(简化代码)显示它:">值例如:3L、3C、3R。(L代表左,C代表中心,4代表右)。我想要订购的值,例如:3L、3C、3R而不是3C、3L、3R我不知道如何定义这个自定义顺序。有什么想法吗? 最佳答案 尝试这样的事情:(app/models/designator.rb)#determinesthesortvalueforbasedonmy_attribute.#designatorsshoul
我有一个简单的问题。我有一个带有created_at的实例变量。我如何将其转换为Month,day,year~September,13,1987当我尝试=@example.created_at在我看来它给了我1987-09-13奇怪的是,当我在控制台中执行此方法时,我得到了Sun,13Sep1987如何将我的变量转换为月、日、年?为什么它在控制台中返回不同的东西? 最佳答案 您可以通过指定格式来更改日期的显示方式,例如@example.created_at.strftime("%B,%d,%Y")#=>"September,20,2
这怎么可能?Time.now.utc.to_date+1.month+15.days#=>Mon,01Dec2014Time.now.utc.to_date+15.days+1.month#=>Sun,30Nov2014有人看过吗?/编辑我想我问错了问题。那你们怎么解释呢?Time.now.utc.to_date+(15.days+1.month)#=>Mon,08Dec2014Time.now.utc.to_date+(1.month+15.days)#=>Tue,09Dec2014(15.days+1.month)#=>3888000(1.month+15.days)#=>3888
我知道关于其中一些主题有很多问题,但我没有找到涵盖所有方面的问题。考虑User、Activity和Like模型。当我查询一个事件时,我想为集合中的每个事件加载第一个Like而不进行N+1查询并且不加载超过必要的记录。我的代码看起来像这样:classUser{order(created_at::asc)},class_name:"Like"endclassLike我做了一个全面的要点来测试不同的加载策略和方法:https://gist.github.com/thisismydesign/b08ba0ee3c1862ef87effe0e25386267策略:N+1查询、左外连接、单次额外查
我正在使用Rails建立一个具有特定销售模式的商店。我需要允许用户每30天只向他的订单添加3件商品。30天计数器应在添加第一个order_item时开始。一旦30天到期,用户将能够添加3个订单。例如,如果30天没有过去,用户添加了两个order_items,他仍然可以在30天内再添加一个order_item。因此,如果用户尝试添加超过3个项目以显示错误消息并忽略将order_items保存到current_user的订单。我有产品、订单、order_items、用户。我想我应该向用户模型添加一些东西,但我不确定是什么。order_items_controller.rbdefcreate
在Rails/Ruby中,我如何根据表中的日期列按月分组和聚合度量。我尝试了Railscasts中的以下技术。http://railscasts.com/episodes/29-group-by-month到目前为止,我的代码是这样的result=result.where(transaction_date:start..Date.current)result=result.select(:transaction_date,:quantity)result.group_by{|t|t.transaction_date.beginning_of_month}我想,我需要一个与SQLGROU