草庐IT

记录写了6年代码的心得

全部标签

sql - 如何将嵌套集中的所有记录呈现为真正的 html 树

我正在使用awesome_nested_set我的Rails项目中的插件。我有两个看起来像这样的模型(简化):classCustomer:customer_idvalidates_presence_of:name#Furthervalidations...end数据库中的树按预期构建。parent_id的所有值,lft和rgt是正确的。树有多个根节点(这在awesome_nested_set中当然是允许的)。现在,我想在正确排序的树状结构中呈现给定客户的所有类别:例如嵌套标签。这不会太困难,但我需要它是高效的(sql查询越少越好)。更新:发现可以计算树中任何给定节点的子节点数,而无需进

ruby-on-rails - Rails 3. before_destroy 验证以防止删除父记录

我有发货和发票。发票属于出货cargo有一张发票如果货件确实有发票,则不应删除货件。我需要在模型中进行设置,因为我使用的是ActiveAdmin。所以我在shipment.rb中这样做了has_one:invoicebefore_destroy:check_for_invoiceprivatedefcheck_for_invoiceunlessinvoice.nil?self.errors[:base]但我只是收到一条黄色消息,提示“货件无法删除”,但实际上它已被删除。如何防止货件被删除? 最佳答案 before_destroy回调

ruby-on-rails - 如何加快为 rspec 测试创建 5,000 条记录的速度?

我正在使用RubyonRails3.2.2、FactoryGirl3.1.0、FactoryGirlRails3.1.0、Rspec2.9.0和RspecRails2.9.0。为了测试我的应用程序,我必须在数据库中创建大量记录(大约5000条),但是该操作非常慢(创建记录需要10多分钟)。我这样进行:before(:each)do5000.timesdoFactoryGirl.create(:article,)endend如何改进我的规范代码以加快速度?注意:可能速度较慢是由在每个文章创建过程前后运行的(5)个文章回调引起的,但我可以跳过这些(因为我唯一需要测试的是文章和不是关联的模型

ruby - 用 YARD 记录 "splatted"参数的最佳方法?

关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我有一个方法应该接受任何类的1+个参数,类似于Array#push:defmy_push(*objects)raiseArgumentError,'Needs1+arguments'ifobjects.empty?objects.eachdo|obj|puts"Anobjectwaspushed:#{obj.inspect}"@my_array.pushobjendend使用YARD语法记

ruby - 如何将 ruby​​ 记录器格式化为此?

ruby记录器的默认样式是:SeverityID,[DateTimemSec#pid]SeverityLabel--ProgName:message#=>D,[2013-11-25T13:31:03.451024#38180]DEBUG--:我想让它看起来像:SeverityLabel[DateTimemSec#pid]:message#=>DEBUG[2013-11-25T13:31:03.451024#38180]:我知道我可以这样格式化它:logger.formatter=procdo|severity,datetime,progname,msg|"severity[#{date

ruby-on-rails - 如何记录某个 url 的整个请求( header 、正文等)?

我需要将所有请求(包括HTTPheader、正文等)记录到某个url。我试过这段代码:defindexglobal_request_loggingendprivatedefglobal_request_logginghttp_request_header_keys=request.headers.keys.select{|header_name|header_name.match("^HTTP.*")}http_request_headers=request.headers.select{|header_name,header_value|http_request_header_key

ruby-on-rails - 使用 seed.rb 文件创建记录时出现 CarrierWave::FormNotMultipart 错误

我有一个包含image列的模型。我正在使用CarrierWave上传图片(我正在关注此railscast以执行此操作。现在,我想使用seed.rb文件创建一些默认记录,但我未能为图像提供正确的parh/url。因此,我在列表项app/public/images/文件夹中有图像,这是seed.rb文件中的代码:gems={test1:{name:'test1',description:'test1',image:'/public/images/test1.png',},test2:{name:'test2',description:'test2',image:'/public/image

ruby - Time.advance 记录在哪里?

在网络上四处寻找,我发现RubyTime类有Time#advance。这在哪里记录?我在RubyAPI文档中没有看到它的提及here.API文档的搜索功能表明在任何地方都没有名为“advance”的方法。尽管如此,在IRB中......>>t=Time.now=>ThuMar0516:08:57-08002009>>t.advance:months=>1=>SunApr0516:08:57-07002009另一件让我感到困惑的事情......在时间类的文档中,它说的第一件事是“实现time.rb库文档中描述的时间类的扩展。”他们的意思是“time.rb库实现了对这个类的扩展吗?”我想也

ruby - 如何将 Ruby Sequel 日志记录设置为 DEBUG 级别?

默认的RubySequel行为是在INFO级别记录所有数据库查询(不同于在DEBUG级别记录的ActiveRecord)。我该如何更改? 最佳答案 以前,使用代理记录器对象相当简单,但是有足够多的人要求我实现它。使用Sequel的gitmaster分支,您现在可以:DB.sql_log_level=:debug这将在记录查询时使用调试方法而不是信息方法。 关于ruby-如何将RubySequel日志记录设置为DEBUG级别?,我们在StackOverflow上找到一个类似的问题:

ruby-on-rails - 事件记录中缺少属性

我有模型Foo和Bar。Bar有列foo_id。当我调用Bar.foo_id时,出现错误missingattribute:foo_id请记住,这不是未定义的方法错误,该列肯定在数据库中。这有哪些常见原因?谢谢 最佳答案 可能和你的find方法有关?例如,您在查找中执行了:select:Foo.find(:all,:select=>"firstvar,secondvar")在那种情况下,即使您定义了foo_id,您也只能访问firstvar和secondvar希望对您有所帮助!=) 关于r