1

これを考えるのに苦労していますが、基本的には、多くのアセットを持つことができるAssetsというElixirクラスを作成したいと思います。したがって、次のようになります(ただし、これは明らかに機能しません)。

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

ですから、私は資産の「フラットな」システムを持ちたいと思っていますが、それが可能であるか、あるいは最善であるかはわかりません。

これを行う方法はありますか?

4

2 に答える 2

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)

クラス定義内で自己参照を作成できないため、managerおよび_idフィールドは「モンキーパッチ」であることに注意してください。manager

于 2011-07-21T21:46:53.913 に答える
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]

そしてそれは動作します。大好きです!

于 2011-07-22T15:56:56.093 に答える