Рельсы named_scopes с соединениями - PullRequest
20 голосов
/ 03 октября 2008

Я пытаюсь создать named_scope, который использует соединение, но хотя сгенерированный SQL выглядит правильно, результат - мусор Например:

class Clip < ActiveRecord::Base      
  named_scope :visible, {
    :joins => "INNER JOIN series ON series.id = clips.owner_id INNER JOIN shows on shows.id = series.show_id", 
    :conditions=>"shows.visible = 1 AND clips.owner_type = 'Series' "
  }

(клип принадлежит серии, серия принадлежит шоу, шоу может быть видимым или невидимым).

Clip.all делает:

SELECT * FROM `clips` 

Clip.visible.all делает:

SELECT * FROM `clips` INNER JOIN series ON series.id = clips.owner_id INNER JOIN shows on shows.id = series.show_id WHERE (shows.visible = 1 AND clips.owner_type = 'Series' ) 

Это выглядит хорошо. Но получившийся массив моделей Clip включает в себя Clip с идентификатором, которого нет в базе данных - вместо этого он взял идентификатор шоу. Куда я иду не так?

Ответы [ 2 ]

26 голосов
/ 03 октября 2008

Проблема в том, что «SELECT *» - запрос выбирает все столбцы из клипов, серий и показывает в этом порядке. Каждая таблица имеет столбец идентификатора, что приводит к конфликтам между именованными столбцами в результатах. Последний извлеченный столбец идентификаторов (из шоу) переопределяет тот, который вы хотите. Вы должны использовать опцию: select с: joins, например:

named_scope :visible, {
  :select => "episodes.*",
  :joins => "INNER JOIN series ON series.id = clips.owner_id INNER JOIN shows on shows.id = series.show_id", 
  :conditions=>"shows.visible = 1 AND clips.owner_type = 'Series' "
}
5 голосов
/ 03 октября 2008

Это ошибка:

http://rails.lighthouseapp.com/projects/8994/tickets/1077-chaining-scopes-with-duplicate- присоединяется к-причины псевдоним проблема

...