Tag: arel

如何使用Active Record查找具有重复数据的记录

使用ruby和新的Activerecord在列中查找具有重复值的记录的最佳方法是什么?

如何在ARel中使用CONCAT()等函数?

有没有办法让ARel写入(清理,可能是别名等)列名到CONCAT()和其他SQL函数中? 以下是使用AVG()的方法 … ?> name = Arel::Attribute.new(Arel::Table.new(:countries), :name) => # population = Arel::Attribute.new(Arel::Table.new(:countries), :population) => # Country.select([name, population.average]).to_sql => “SELECT `countries`.`name`, AVG(`countries`.`population`) AS avg_id FROM `countries`” (是的,我知道avg_id在每一行都是一样的,只是试图说明我的问题) 那么如果我想要一个不同的function呢? ?> Country.select(xyz).to_sql # Arel::Concat.new(name, population) or something? => “SELECT CONCAT(`countries`.`name`, ‘ ‘, `countries`.`population`) AS concat_id FROM `countries`” 谢谢!

怎么做Arel中的“where exists”

你如何进行包含Arel中“where exists”的查询? 例如,在这样的查询中,向所有供应商显示至少一个订单: SELECT * FROM suppliers WHERE EXISTS (SELECT * FROM orders WHERE suppliers.supplier_id = orders.supplier_id); 我在Arel文档http://rubydoc.info/gems/arel/2.0.7/Arel/Nodes/Exists中看到“存在”,但我在使用它时遇到了麻烦。