2011-08-30 17 views
10

on Rails 3.1 RC6, zważywszyActiveRecord STI: Jak mogę wyjść z klasy nadrzędnej default zakres

class Animal < ActiveRecord::Base 
    default_scope where(legs: 4) 
end 

Poniższa nie działa zgodnie z oczekiwaniami:

class Man < Animal 
    default_scope unscoped.where(legs: 2) 
end 

Powstały SQL wygląda tak:

SELECT * FROM animals WHERE legs = 4 AND legs = 2 

Jak całkowicie zmienić domyślny zakres klasy macierzystej?

Próbowałem również następne z których żadna praca:

default_scope{ unscoped.where legs: 2 } 
default_scope with_exclusive_scope{ legs: 2 } 

Odpowiedz

8

I wbił kod źródłowy Rails i wpadł na rozwiązanie, które działa pod Rails 3.1 (testowane z ActiveRecord 3.1.0.rc6):

class Animal < ActiveRecord::Base 
    default_scope where(legs: 4) 
end 

class Man < Animal 
    self.default_scopes = [] 
    default_scope where(legs: 2) 
end 
+0

Wydaje się, że to działa w Rails 3.0: self.default_scoping = [] – jemminger