2011-07-21 102 views
1

我在思考這個問題時遇到了困難,但基本上我想創建一個名爲Assets的Elixir類,它可以擁有多個Assets。因此,它可能看起來像這樣(但不工作,很明顯):如何創建一個與自己有ManyToMany關係的Elixir類

class Asset(Entity): 
    has_field('Name', Unicode) 
    has_many('Assets', of_kind='Asset', inverse='Assets') 

所以,我希望能夠有資產的「平」系統,但我不知道它可能甚至最好。

有沒有辦法做到這一點?

回答

1

我明白了,謝謝@wberry的一些見解。在藥劑:

class Asset(Entity): 
    has_field('Name', Unicode) 
    Assets = ManyToMany('Asset') 

利用這一點,我可以做瘋狂的事情是這樣的:

a1 = Asset(Name=u'Asset 1') 
a2 = Asset(Name=u'Asset 2') 
a3 = Asset(Name=u'Asset 3') 

a1.Assets=[a1,a2,a3] 

和它的作品。我喜歡它!

+0

很高興爲您服務。 Elixir語法看起來很乾淨,我必須仔細研究它。 – wberry

+0

這是瘋狂的乾淨的,如果你遇到了它的限制,你幾乎可以開始編寫sqlalchemy,而你正處於隱藏狀態。 – MFB

2

我不懂Elixir,但這是如何使用SQLAlchemy聲明來完成的。希望Elixir的定義可以相似,這對你有幫助。

from sqlalchemy.ext.declarative import declarative_base 
Base = declarative_base() 

class Employee(Base): 
    __tablename__ = 'employee' 
    id = Column(Integer, primary_key=True) 
    name = Column(String(64), nullable=False) 
Employee.manager_id = Column(Integer, ForeignKey(Employee.id)) 
Employee.manager = relationship(Employee, backref='subordinates', 
    remote_side=Employee.id) 

注意,managermanager _id字段是「猴子打補丁」,因爲你不能在一個類定義內作出自我引用。

+0

謝謝你,這使我找到了解決辦法! – MFB

+1

你介意與他人分享你的解決方案嗎?作爲單獨的答案發布並接受它。並且提出導致解決方案的答案也是一個好主意。 – van

+0

是的,去了崗位答案,但不能由於時間的限制。現在做 – MFB

相關問題