PostgreSQL
 sql >> Base de données >  >> RDS >> PostgreSQL

Relation Rails Activerecord :utilisation d'une sous-requête comme table pour une instruction de sélection SQL

Utilisez le from() méthode depuis l'interface Active Record.

Par exemple :

@subquery = table_a.select("DISTINCT ON(table_a.id) table_a.name as alias_a, table_b.time")     
@subquery = @subquery.joins("LEFT OUTER JOIN table_b ON table_a.id = table_b.id")
@subquery = @subquery.order("table_a.id, table_b.time asc")

Utilisez-le ensuite comme ceci dans la requête externe :

@query = OtherModel.from("(#{@subquery.to_sql}) table_name, other_model_table, etc ...").where(:field => table_name.alias_a) ...etc.