草庐IT

sql - 如果我经常 ORDER BY o.creationDate - 我应该用 @Index 标记 creationDate 吗?

全部标签

sql - 在 Rails 中进行计数的正确方法是什么?

我有一个包含以下许多代码片段的Rails应用程序:Ouractivecommunityof我的问题是,这是计算观看次数的正确方法吗?看起来很“肮脏”,有没有更粗鲁的方法来计算?我可能在考虑命名范围,但我只是想确保这些类型的东西不会对性能产生更大的影响。谢谢你, 最佳答案 您不需要名称范围来执行计数。Account.where(:admin=>false).count但是命名作用域是使您的代码更具可重用性的绝佳方式。命名范围不会对您的应用程序产生任何明显的性能影响。 关于sql-在Rail

ruby - 为什么不应该使用 Ruby 来创建蜘蛛

在Joel&Jeff播客的第78集中,Doctype/Litmus的一个人说你永远不会想用ruby​​构建蜘蛛。有人想猜猜他这样做的原因吗? 最佳答案 无论如何,爬虫需要多快?这取决于您是在紧迫的时间内抓取整个网络,还是从一个网站上的几十个页面收集数据。有了Ruby和nokogiri库,我可以阅读thispage并在0.01秒内解析它。使用xpath从已解析的页面中提取数据,我可以在0.16秒内将所有数据转换为特定领域的对象。所有223行。我遇到的传统约束(cpu/内存/磁盘)很重要的问题越来越少。这是一个富足的时代。在资源不受限制

ruby-on-rails - 在什么情况下我应该使用实例变量而不是其他变量类型?

我正在使用RubyonRails3,我想知道在什么情况下我应该使用实例变量而不是其他变量类型,以及这些变量是否有安全原因。例子:#Usinganinstancevariable@accounts=Account.find(...)#Usinga"local"\"normal"variableaccount=Account.find(...) 最佳答案 一般来说,实例变量是局部的,并且持久存在于对象的实例中,而局部变量只是局部的,并且持久存在于函数/对象/block范围内。例如:classUserdefname@nameenddefn

ruby-on-rails - 文章#index 中的 Ruby on Rails 教程 NoMethodError

所以我正在关注http://guides.rubyonrails.org/getting_started.html上的官方ROR教程我被困在第5.8节,它教我如何列出所有文章下面是我的controller和index.html.erbControllerclassArticlesControllerindex.html.erbListingarticlesTitleText我收到带有错误消息的NoMethodErrorinArticles#indexundefinedmethod`each'fornil:NilClass"怎么了?我从网站上复制并粘贴了代码以查看我做错了什么,但仍然无法

ruby - 应该 validate_format_of 。 not_with 在框架中有问题(或者在我的理解中)

我将以下代码放入RSpec测试中:it{shouldvalidate_format_of(:email).not_with('test@test')}并设置实际的类:validates:email,:presence=>true,:format=>/\b[A-Z0-9._%-]+@(?:[A-Z0-9-]+\.)+[A-Z]{2,4}\b/i当我运行测试时,我得到:失败:1)用户失败/错误:它{应该validate_format_of(:email).not_with('test@test')}当电子邮件设置为“test@test”时,预期错误包括“can'tbeblank”,得到错误

ruby - Rails map_with_index?

我有以下内容::participants=>item.item_participations.map{|item|{:item_image=>item.user.profile_pic.url(:small)}}我希望这种情况在内部发生的次数不超过3次。我试过map_with_index但没有用。关于在循环中最多运行3次后如何中断的任何建议? 最佳答案 从Ruby1.9开始,您可以使用map.with_index::participants=>item.item_participations.map.with_index{|item

ruby - 如果这段代码不是在开玩笑,那它究竟是如何工作的呢?

classTreedefinitialize*d;@d,=d;enddefto_s;@l||@r?",>":@d;enddeftotal;(@d.is_a?(Numeric)?@d:0)+(@l?@l.total:0)+(@r?@r.total:0);enddefinsertdaliasginstance_variable_getp=lambda{|s,o|d.to_s.send(o,@d.to_s)&&(g(s).nil??instance_variable_set(s,Tree.new(d)):g(s).insert(d))}@d?p[:@l,:]:@d=dendend有人愿意尝试

ruby - 如果需要,如何使用 gsub 添加尾部斜线

如果需要,我正在尝试添加尾部斜线:a='/var/www'a.gsub...我不知道怎么做。 最佳答案 a=File.join(a,"")快捷、简单,并具有保证a以路径分隔符结尾的效果;也就是说,无论a是"/var/www"还是"/var/www/",它都会给出相同的结果。这与上面JoeWhite的评论相同;我不知道他为什么不提交它作为答案,因为它应该是一个。奇怪的是,Pathname库没有提供一种方便的方法来做同样的事情。 关于ruby-如果需要,如何使用gsub添加尾部斜线,我们在S

ruby-on-rails - 验证事件连接!在 Rails 4 中已弃用,我们应该如何处理该功能?

我一直在关注这篇文章以与工头一起设置puma:https://www.digitalocean.com/community/articles/how-to-set-up-zero-downtime-rails-deploys-using-puma-and-foremanpuma脚本在连接后告诉verify_active_connections!但它在rails4中不可用。注释掉方法调用将使脚本运行但我不确定这是否会泄漏资源.关于这个问题,我能看到的唯一文档是:https://github.com/socialcast/resque-ensure-connected/issues/3但是

ruby-on-rails - 对于新的 ActiveRecord 模型,为什么有些 has_many :through associations add a (1=0) predicate and distinct clause to the sql query?

每当我实例化一个新的ActiveRecord模型(一个尚未持久化到数据库中的模型)并尝试访问构建模型上的一些各种关联时,Rails查询构建器有时会:将(1=0)谓词添加到查询的where子句。在select语句中添加“distinct”子句。我认为这只会在has_many:through关联连接两个或多个表时发生。我想知道为什么它添加了(1=0)谓词以及distinct子句。对于(1=0)谓词,新模型是否已保存到数据库应该无关紧要(对吧?)。我不知道为什么要添加distinct子句。我在下面有一个简单的例子。classAssignment#s.assignment_attachment