如何创建与自身具有ManyToMany关系的Elixir类

时间:2011-07-21 21:07:59

标签: python sqlalchemy python-elixir

我很难想到这一点,但基本上我想创建一个名为Assets的Elixir类,它可以有很多资产。所以,它可能看起来像这样(但显然不起作用):

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

所以,我希望能够建立一个“扁平”的资产系统,但我不确定它是否可能,甚至是最好的。

有没有办法做到这一点?

2 个答案:

答案 0 :(得分: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字段是“猴子修补的”,因为您无法在类定义中进行自引用。

答案 1 :(得分:1)

由于来自@wberry的一些见解,我明白了。在Elixir:

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]

它有效。我喜欢它!