• Rust leetcode at 2017年1月18日

    感觉开repo和发帖对于刷题来说就是flag一样的存在....

  • #9楼 @kimmg 传nil是不可能报argument error的,他的cart.rb写的有问题,报错在cart.rb:2

  • midori 百日记 at 2017年1月14日

    yehuda的博客说过ruby的db adapter在多线程下都是不会阻塞的,file的话不清楚,如果对file的接口做同样的处理,那么是不是即使不用em,普通的多线程也可以把cpu跑满呢?

  • 当你有几个子类要继承同一个父类,但是并不是STI的时候,在父类声明abstract_class,在子类声明各自的table_name http://api.rubyonrails.org/classes/ActiveRecord/Inheritance/ClassMethods.html

    ApplicationRecord就是个abstract class,他是ActiveRecord::Base和你的实际model中间的一层,使你对ApplicationRecord的扩展不会影响ActiveRecord::Base。而要做到这个,常规情况你需要有个名为application_records的表。

  • 因为要用uglify.js压缩js代码

  • 按需取用吧,**的好处是以下情况可以正确捕获

    def t a = 1, b, **c
      p a,b,c
    end
    
    def t2 a = 1, *b, **c
      p a,b,c
    end
    
    t 1, a: 1      #=> 1   1            {:a=>1}
    t 1, 'a' => 1  #=> 1   {"a"=>1}     {}
    
    t2 1, a: 1     #=> 1   []           {:a=>1}
    t2 1, 'a' => 1 #=> 1   [{"a"=>1}]   {}
    

    行为各异,能用就好

  • https://ruby-china.org/topics/29703 用这个你还可以用lisp开发ruby,不用任何扩展

  • #5楼 @flemon1986 应该也行,还差个foreign_key,只是用Product还是用ReviewSummary来实例化的问题,反正avg_star肯定读的到的

  • 熊没了....

  • #3楼 @flemon1986 我找到办法了

    class Product
      has_many :reviews
      has_one :review_summary
    end
    
    class ReviewSummary < ApplicationRecord
      self.table_name = 'reviews'
      default_scope {
        from('products').
          joins('INNER JOIN reviews ON reviews.product_id = products.id').
          select('products.id as product_id, avg(stars) as avg_star')
      }
    
    end
    

    然后

    p = Product.includes(:review_summary).first
    p.review_summary.avg_star # => 平均评分
    

    这样就可以利用includes把统计数据都查出来了,生成的查询是这样的

    SELECT products.id as product_id, avg(stars) as avg_star FROM products INNER JOIN reviews ON reviews.product_id = products.id WHERE "reviews"."product_id" IN (1, 2)
    

    上面是用reviews.product_id用来做where条件的,可能有点巧合的感觉,一种更好的配法是

    class ReviewSummary < ApplicationRecord
      self.table_name = 'products'
    
      default_scope {
        joins('INNER JOIN reviews ON reviews.product_id = products.id').
          select('products.id as id, avg(stars) as avg_star')
      }
    
    end
    
    class Product < ApplicationRecord
      has_many :reviews
      has_one :review_summary, foreign_key: :id
    end
    

    生成的查询是:

    SELECT products.id as product_id, avg(stars) as avg_star FROM products INNER JOIN reviews ON reviews.product_id = products.id WHERE "products"."id" IN (1, 2)
    

    用products.id来写where正是我们想要的行为,完美。。这样虚拟出关联还是相当好玩的,不用create view了