jjzjj

find_or_initialize

全部标签

ruby - 如何优化 ActiveRecord find_in_batches 查询?

我正在使用Rails4.0.0和Ruby2.0.0。我的Post(如在博客文章中)模型与用户相关联,该用户具有用户的user_name、first_name、last_name的组合。我想迁移数据,以便通过外键(即用户ID)将帖子关联到用户。我在posts表中有大约1100万条记录。我在Linux服务器上使用rake任务运行以下代码来迁移数据。然而,我的任务一直被服务器“杀死”,大概是由于rake任务,特别是下面的代码,消耗了太多内存。我发现将batch_size降低到20并将sleep(10)增加到sleep(60)允许任务运行更长的时间,在不被杀死的情况下总共更新更多的记录,但需要

ruby - LoadError 通过要求带有 :path or :git 的 gem

我遇到了一个非常奇怪的问题。我在github上fork了一个gem来做一些修改,在我的本地机器上克隆了我的repo,进行了更改并更改了另一个项目的Gemfile以从我的本地存储库中获取gem以进行测试。不幸的是,我在我的ruby​​脚本中需要该gem时遇到LoadError。rvmcurrent=>ruby-1.9.3-p448ruby--version=>ruby1.9.3p448(2013-06-27revision41675)[x86_64-linux]bundle--version=>Bundlerversion1.3.5我的Gemfile的内容:source'http://r

Ruby:Titleize:如何忽略较小的词,如 'and' 、 'the' 、 'or 等

deftitleize(string)string.split("").map{|word|word.capitalize}.join("")end这会标题化每个单词,但我如何捕捉某些我不想大写的单词?即)jack和吉尔请不要使用正则表达式。更新:我在使这段代码工作时遇到了问题:我让它打印了一个全部大写的单词数组,但并非没有下面的列表。words_no_cap=["and","or","the","over","to","the","a","but"]deftitleize(string)cap_word=string.split("").map{|word|word.capitali

ruby - 什么在 Ruby : defining the alias method or using alias_method? 中运行得更快

什么在以后调用时更快:deffirst_method?()second_method?()end或alias_method:firstmethod,:second_method如果可能的话,为什么?(注意:我不问什么更好/更好等等->这里只有原始速度以及为什么它更快很有趣) 最佳答案 至少在Ruby1.8.6中,别名似乎更快:#!/usr/local/bin/rubyrequire'benchmark'$global_bool=trueclassObjectdeffirst_method?$global_boolenddefseco

ruby-on-rails - gem install nokogiri -v '1.5.11' 由于 make :/usr/local/bin/gmkdir: No such file or directory 而失败

Rubyversion:2.2.5MacOSX:10.11.5Gemversion:2.4.8Bundlerversion:1.12.5当我运行geminstallnokogiri-v'1.5.11'时,出现以下错误:Buildingnativeextensions.Thiscouldtakeawhile...ERROR:Errorinstallingnokogiri:ERROR:Failedtobuildgemnativeextension./Users/hwpeng/.rvm/rubies/ruby-2.2.5/bin/ruby-r./siteconf20160707-31800-

Ruby 范围,常量优先级 : lexical scope or inheritance tree

我将向您展示来自rubykoans的代码片段教程。考虑下一个代码:classMyAnimalsLEGS=2classBird实际上问题在评论中(我用星号突出显示了它(尽管它打算以粗体显示))。有人可以解释一下吗?提前致谢! 最佳答案 这里有答案:Ruby:explicitscopingonaclassdefinition.但也许它不是很清楚。如果您阅读链接的文章,它将帮助您找到答案。基本上,Bird是在MyAnimals的范围内声明的,在解析常量时具有更高的优先级。Oyster位于MyAnimals命名空间中,但未在该范围内声明。将

ruby-on-rails - 信用系统 : history based or balance based?

我打算写一个简单的信用系统,用户可以在系统中“添加”、“扣除”信用。目前我正在考虑两种方法。简单一:将用户的信用存储为数据库中的balance字段,记录所有操作(“add”、“deduct”)但不用于计算最新余额.基于历史:不要将余额存储在数据库中。余额是通过查看交易历史来计算的,例如(“加”,“减”)我认为这两种情况都可行,但我希望了解在设计此类系统时是否有任何注意事项,特别是我更喜欢Historybased系统。或者,有没有我正在使用的引用实现或开源模块?更新:或者是否有任何基于Ruby/Rail的模块,例如AuthLogic,这样我就可以即插即用我现有的代码而无需重新发明轮子(例

ruby-on-rails - 为什么我会收到此 Passenger 错误 Could not find rake-0.9.2.2 in any of the sources?

我刚刚创建了一个新的空Rails应用程序,它几乎是空的。我创建它只是为了找出问题所在,但我收到了以下错误。我正在使用Rails3.1.0和Ruby1.9.2Errormessage:Couldnotfindrake-0.9.2.2inanyofthesources(Bundler::GemNotFound)Exceptionclass:PhusionPassenger::UnknownError所以我将rake-0.9.2.2添加到Gemfile并运行bundle,但我仍然收到相同的错误消息。我不知道问题出在哪里,我什至尝试打开Rails日志文件,但里面什么也没有。我尝试了很多次以不同

ruby-on-rails - 使用 ActiveRecord find_in_batches 方法删除大数据

好的,所以我知道在处理非常大的数据时,我们可以使用find_in_batches,据我所知,它完成了Model.all.each的工作以一种非常快速的方式,效率更高现在,我有一个非常大的数据要删除,我正在考虑使用相同的find_in_batches来批量删除它们。下面是我所拥有的(来自rake任务database.rake):old_messages=TextMessage.where("created_at但是,当我运行它时,出现以下错误:ArgumentError:wrongnumberofarguments(0for1..3)/Users/Sunday/.rvm/gems/rub

ruby - IntelliJ IDEA "Cannot find ' 需要'"

将Ruby插件与IntelliJ一起使用时,我应该期望/容忍哪些“undefinedreference”警告,以及哪些表明我没有正确配置的内容?例如,我收到关于“require”、“File”和“FileUtils”的“无法找到”警告。我怀疑这表示存在配置问题。我还收到有关RSpec方法的警告,例如“描述”、“之前”、“之后”和“它”。我还应该能够配置IntelliJ来“找到”这些吗? 最佳答案 需要在项目结构中选择RubySDK(Ctrl+Alt+Shift+S默认情况下)。不幸的是,它没有解决rspec相关词的警告。