如何在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`"
谢谢!
使用NamedFunction
:
name = Arel::Attribute.new(Arel::Table.new(:countries), :name) func = Arel::Nodes::NamedFunction.new 'zomg', [name] Country.select([name, func]).to_sql
- NameError:has_many通过关系的未初始化常量
- 在Rails 4中的has_and_belongs_to_many关系中使用uniq
- 如何通过连接表中的条件接收对象
- 独立ruby – 如何从database.yml加载不同的环境
- 有没有办法validationActiveRecord上的特定属性而不首先实例化对象?
- Ruby on Rails模型。 为什么范围为1的十进制{2,1}允许小数点后的数字?
- 如何在ActiveRecord中进行自反的自我加入关系?
- Rails中的composed_of – 什么时候使用它?
- Rails .reject将类型ActiveRecord :: Relation转换为类型数组