• MainCombinePackageItem.joins('INNER JOIN packages main_package ON main_package.id = main_combine_package_items.main_package_id')
                          .joins('INNER JOIN packages combined_package ON combined_package.id = main_combine_package_items.combined_package_id')
                          .where('main_package.state NOT IN ? or combined_package.state NOT IN ?', [9, 10], [9, 10])
                          .where(warehouse_id: 1)
    

    像楼上说的not in如果用不到索引的话,可以改成in,一共有哪些状态是知道的

  • rails在joins和eager_load同一个表的时候会加上别名的:

    MainCombinedPackageItem.joins(:main_package, :combined_package)
    
    SELECT "main_combined_package_items".* FROM "main_combined_package_items" INNER JOIN "packages" ON "packages"."id" = "main_combined_package_items"."main_package_id" INNER JOIN "packages" "combined_packages_main_combined_package_items" ON "combined_packages_main_combined_package_items"."id" = "main_combined_package_items"."combined_package_id"
    

    第二个packages表加了combined_packages_main_combined_package_items的别名,可以直接在where用,但是我觉得这样不好,干脆直接写sql或者用把sql拆成手写的joins() where()

  • 惊了可还行,怕不是真实猛男(滑稽

    不过ruby用的不是引用计数,是mark and sweep: http://blog.jobbole.com/60900/

  • 只要记住ruby里传递的永远是引用就好了,包括数字传的也是引用,不提供代码块,只提供一个对象引用的话,这个对象不一定是可复制的(虽然数组可以),所以Array.new肯定不会帮你复制

  • 嗯,我看看

  • 有具体点的信息吗?

  • Map for hash array using &: at 2017年04月30日

    反正Array#to_proc也没人用,自己定义一个就好了

    class Array
      def to_proc
        ->(x){ x[first] }
      end
    end
    
    p [{aa: 1}, {aa: 2}].map(&[:aa]) #=> [1, 2]
    
  • 我觉得你应该要用的是GetForegroundWindow,参照 http://stackoverflow.com/questions/10740143/get-current-active-window-title-in-c GetActiveWindow 只能get你自己进程里的。

    另外win32api和dl已经deprecate,建议使用fiddle或ffi:

    require 'fiddle'
    require 'fiddle/import'
    require 'fiddle/types'
    
    module User32
      extend Fiddle::Importer
      dlload 'user32'
      include Fiddle::Win32Types
    
      extern 'HWND GetForegroundWindow()'
      extern 'int GetWindowText(HWND, char*, int)'
    end
    
    title = "\0" * 255
    hwnd = User32.GetForegroundWindow
    length = User32.GetWindowText(hwnd, title, 255)
    p title[0...length]
    
  • ancestry不能includes和eager_load,会多很多n+1查询的。。closure_tree可以把grandparent之类的实现成真正的关联,用起来方便很多

  • Slimming-Controllers at 2017年04月11日

    十行不到的代码也能yy出这么多pattern。。

  • 有人一起 Mastodon 吗? at 2017年04月08日

    搞好了,是nginx里要用fullchain.cer,之前用错了。。

  • 有人一起 Mastodon 吗? at 2017年04月08日

    建了一个 me@abysswalking.net,能看到吗?

    好像别人都看不到我,不知道哪里搞错了。。。

  • ruby有个钩子叫method_added,然后拿到名字以后,用instance_method把方法拿出来,再bind(xx).call就好了,这样可以不用写eval字符串(虽然可能更快)

  • 发两次请求还有一种可能是chrome插件导致的,可以开隐身窗口排查一下

  • 但是ruby的核心之一是打开类,在运行时修改类定义,所以编译期查找方法是不可能的;假如需要缓存方法路径,现在也可以缓存,这个和有没有类型应该没关系。

    另外matz很讨厌java那种手写types,ruby不可能会做成java这样的。。Ruby3大概会给你照respond_to?推一下,类ruby的静态类型语言可以参照crystal,但是我觉得没有意义,想真的要享用类型系统的好处的话,还是建议去用rust或者haskell。。。

  • 用 Ruby 做编译原理大作业 at 2017年03月14日

    嗯。。类型定义应该要先跑一遍。。宏的话我自己都还不会用= =

  • 有了类型之后又会想要积类型 和类型,递归类型,依存类型。。。在没有完美的类型体系之前我觉得鸭子类型才是最好的。。。

  • Ruby China 正在衰退吗? at 2017年03月12日

    能跳js和go说明不懂ruby的一分一毫啊...

  • 求推荐机械键盘 at 2017年03月04日

    红轴比茶轴好。。茶轴杂音多而且毛毛的触感,你喜欢轻的话茶轴会不够轻,品牌可以随意,只要是cherry原厂轴就行

  • md5是摘要算法,不可逆,1g的文件md5也是32个字符

  • 嗯,你可以用htop看看内存使用情况,一般而言128m对rails进程是不够的,刚刚试了一下,一个空的rails项目,开发环境启动就要68M,进行一个空页面的请求之后已经96M了。

  • 读 RubyGems 源码遇到的问题 at 2017年02月28日

    底下有rescue

  • 128m…估计炸得不能再炸了……

    如果项目大,开发环境渲染views确实可以占到几秒甚至十几秒,但是我觉得你这个应该是爆内存然后跑到swap导致慢

  • 正常来讲不是应该一个api一个域名么。。不然怎么区分哪个url是哪个用户的,难道添加的时候先检查占用?所以直接开多个Rails应用,然后把数据库里的路由导入成rails路由就可以了。。。

    另外我觉得这个controller怎么设计也还很多疑问,如果开应用成本太高,不一定要用rails的。。

  • Rust leetcode at 2017年01月18日

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