这是一个棘手的问题。我有一个包含多种内容类型的项目,例如文章、评论等。每种内容类型都有评论,评论是多态的,因为它们可以属于任何内容类型。我想在我的所有内容页面上放置一个评论总数计数器以显示有多少评论,并且我实现了一个计数器缓存来执行此操作。(@article.comments.count之类的查询更多,并且由于我将Ancestrygem用于线程评论,因此子评论不计入该数字,仅计入根评论。)计数器缓存运行良好并显示评论的准确数量,但一如既往地有一个小问题。评论并不总是立即发布,只有注册用户才能立即发布,并且这些评论的:status为“2”。未注册用户进入审核队列;这些评论的:status
我有这段代码:date_counter=Time.mktime(2011,01,01,00,00,00,"+05:00")@weeks=Array.new(date_counter..Time.now).step(1.week)do|week|logger.debug"WEEK:"+week.inspect@weeks从技术上讲,代码有效,输出:SatJan0100:00:00-05002011SatJan0800:00:00-05002011SatJan1500:00:00-05002011etc.但是执行时间完全是垃圾!每周计算大约需要四秒钟。我在这段代码中是否遗漏了一些奇怪的低效
假设我有Book模型和Author模型。我想列出所有按书数排序的作者。最好的方法是什么?我知道如何在SQL中执行此操作,方法是使用嵌套选择或某些连接执行where..in。但我想知道的是如何使用ActiveRecord很好地做到这一点。 最佳答案 正如Kevin所建议的,counter_cache是最简单的选项,我绝对会使用它。classAuthortrueendclassBook如果您使用的是Rails2.3,并且您希望这是默认顺序,您可以使用新的default_scope方法:classAuthortruedefault_sco
几天来,我一直在努力弄清楚什么接缝是应该很容易做到的事情......然而,我对rails和ruby的世界还是很陌生,我就是无法解决这个问题一出...:p无论如何,我遇到的问题是我的模型中有许多:counter_cache列,在手动测试它们时它们都工作得很好。但是我想做TDD的事情,但由于某些未知原因我无法在rspec中测试它们?无论如何,这是我的模型(用户、评论和媒体)的示例:classUsertruebelongs_to:user,:counter_cache=>truevalidates:user_id,:presence=>truevalidates:content,:pre
我有以下场景:我需要在一个非常大的集合中找出唯一的ID列表。例如,我有6000个id数组(关注者列表),每个数组的大小范围在1到25000(他们的关注者列表)之间。我想获得所有这些ID数组中的唯一ID列表(关注者的唯一关注者)。完成后,我需要减去另一个ID列表(另一个人的关注者列表)并获得最终计数。最后一组唯一ID增长到大约60,000,000条记录。在ruby中,将数组添加到大数组时,它开始变得非常慢,大约几百万。添加到集合中一开始需要0.1秒,然后增长到200万时需要超过4秒(离我需要去的地方不远)。我用java编写了一个测试程序,它在不到一分钟的时间内完成了整个过程。也许我在
我刚开始在一个非常小的Sinatra应用程序中使用Sequel。因为我只有一个数据库表,所以我不需要使用模型。我想更新一条记录(如果它存在)或者插入一条新记录(如果它不存在)。我提出了以下解决方案:rec=$nums.where(:number=>n,:type=>t)if$nums.select(1).where(rec.exists)rec.update(:counter=>:counter+1)else$nums.insert(:number=>n,:counter=>1,:type=>t)end其中$nums是DB[:numbers]数据集。我相信这种方式不是“更新或插入”行为
我有这些模型:classChildren我现在需要的是在“电影院”的页面中,我想为那个电影院的电影打印children的总和(数量,大小?),所以我这样写:在cinemas_controller.rb中:@childrens=@cinema.childrens.uniq在cinemas/show.html.erb:但显然我有bulletgem提醒我Counter_cache并且我不知道把这个counter_cache放在哪里因为电影的不同id。而且在没有counter_cache的情况下,我所拥有的也不是我想要的,因为我想要计算该电影院中有多少child从该电影院许多天的门票中拿走了他
据我了解,在定义:counter_cache选项时,应在包含belongs_to声明的模型上指定它。所以我有点不确定在通过关联使用has_may时如何处理这个问题(因为我相信在这种情况下不使用belongs_to声明):classPhysician:appointmentsendclassAppointmentappointment_countendclassPatient我希望使用:counter_cache选项来更有效地查找属于医生的患者数量。myPhysician.patients.count仅供引用:Rails3.1干杯 最佳答案
我刚刚创建了一个counter_cache字段,Controller看起来像这样。@users=User.where(:sex=>2).order('received_likes_count')User.rb中的关联是has_many:received_likes,:through=>:attachments,:source=>:likes,:dependent=>:destroy问题是counter_cache是在Like.rb的belong_to中声明的,我不知道如何告诉它它是用于has_many:through关联。belongs_to:user,:counter_cache=>
dosomething如果未定义dasboard_pane_counter,我如何才能将其评估为false而不是抛出异常? 最佳答案 #do_somethinghere,thisassumesthatdashboard_pane_counterisdefined,butnotnil 关于ruby-on-rails-如何检查Rails中是否定义了变量?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/q