首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >如何创建与其自身具有ManyToMany关系的Elixir类

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

Stack Overflow用户
提问于 2011-07-22 05:07:59
回答 2查看 175关注 0票数 1

我在思考这个问题时遇到了麻烦,但基本上我想创建一个名为Assets的Elixir类,它可以拥有许多资产。因此,它可能看起来像这样(但这显然不起作用):

代码语言:javascript
代码运行次数:0
运行
复制
class Asset(Entity):
    has_field('Name', Unicode)
    has_many('Assets', of_kind='Asset', inverse='Assets')

因此,我希望能够拥有一个“扁平化”的资产系统,但我不确定这是不可能的,甚至是最好的。

有没有办法做到这一点?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2011-07-22 23:56:56

我想通了,多亏了@wberry的一些见解。在Elixir中:

代码语言:javascript
代码运行次数:0
运行
复制
class Asset(Entity):
    has_field('Name', Unicode)
    Assets = ManyToMany('Asset')

使用它,我可以做一些疯狂的事情,比如:

代码语言:javascript
代码运行次数:0
运行
复制
a1 = Asset(Name=u'Asset 1')
a2 = Asset(Name=u'Asset 2')
a3 = Asset(Name=u'Asset 3')

a1.Assets=[a1,a2,a3]

而且它是有效的。我喜欢它!

票数 1
EN

Stack Overflow用户

发布于 2011-07-22 05:46:54

我不精通Elixir,但这就是使用SQLAlchemy声明式的方法。希望Elixir的定义足够相似,这对你有帮助。

代码语言:javascript
代码运行次数:0
运行
复制
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字段是“打补丁的”,因为您不能在类定义中进行自引用。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/6782810

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档