2011-08-30 23 views
10

On Rails 3.1 RC6, traoActiveRecord STI: Làm thế nào tôi có thể thoát ra khỏi tầng lớp phụ huynh phạm vi mặc định

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

Sau đây không hoạt động như mong đợi:

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

Kết quả là câu lệnh SQL trông giống như sau:

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

Làm cách nào để ghi đè toàn bộ phạm vi mặc định của lớp cha?

Tôi cũng đã thử các sau không ai trong số đó làm việc:

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

Trả lời

8

tôi đào vào mã nguồn Rails' và đã đưa ra một giải pháp mà làm việc dưới Rails 3.1 (thử nghiệm với 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

có vẻ rằng đây làm việc trong Rails 3.0: self.default_scoping = [] – jemminger

Các vấn đề liên quan