2011-09-29 44 views
0

我在使用GAE中的PolyModel時使用db.ReferenceProperty時遇到了問題。如果我有兩個從基礎PolyModel派生的模型,並且每個模型都引用了另一個「容器」模型,則容器上的集合包含PolyModel,而不僅僅是您期望的那個。下面是一個顯示問題測試用例:GAE/Python:collection_name不適用於Polymodel?

from google.appengine.ext import db 
from google.appengine.ext.db import polymodel 

class MyContainer(db.Model): 
    name = db.StringProperty(default='mycontainer', multiline=False) 

class MyBaseModel(polymodel.PolyModel):  
    name = db.StringProperty(default='mybasemodel', multiline=False) 

class MyModelOne(MyBaseModel): 
    container = db.ReferenceProperty(MyContainer, collection_name='model_ones') 

class MyModelTwo(MyBaseModel):  
    container = db.ReferenceProperty(MyContainer, collection_name='model_twos') 

print "Beginning test.\n" 
c = MyContainer(name="Container") 
c.put() 
one = MyModelOne(name="One", container=c) 
two = MyModelTwo(name="Two", container=c) 
one.put() 
two.put() 

print "Ones:" 
for o in c.model_ones: 
    print o.name 
print "\nTwos:" 
for o in c.model_twos: 
    print o.name 

和輸出:

Beginning test. 

Ones: 
One 
Two 

Twos: 
One 
Two 

我失去了在建立我的ReferenceProperties的東西,或者是這種預期的行爲?

回答

2

因此,看着SDK source,似乎_ReverseReferenceProperty(它將集合轉換爲Query對象)不會嘗試處理PolyModels。關於問題跟蹤器有幾個相關的投訴,herehere

IMO,如果這是一個已知的限制,它應該在PolyModel文檔中的某處提及。

編輯:集合少的解決方法是這樣的:

for o in MyModelOne.all().filter('container =', c):

+0

謝謝,這證實了我所看到的。我同意文檔缺乏,我可能會提交一個錯誤。你的過濾器工作,這是我的解決方案。在我上面的示例中,如何獲取所有MyBaseModel,而不使用相關的MyModelOne和MyModelTwo? MyBaseModel.all()。filter(「_ class!=」,「MyModelOne」)不起作用。 – Hoser

+0

AFAIK,你不能。過濾kind = MyBaseModel或class = MyBaseModel將匹配所有子類。 'filter(「class!=」,「MyModelOne」)'應該排除MyModelOne,但是你需要多個不相等的過濾器來排除所有的子類。解決方法是手動將類名作爲默認值包含在基礎模型上,並在子模型上設置不同的默認值。然後你可以過濾。 –

相關問題