请教 SQLAlchemy 继承问题

2016-10-12 16:14:32 +08:00
 tanywei
class Employee(Base):
    __tablename__ = 'employee'
    id = Column(Integer, primary_key=True)
    name = Column(String(50))
    type = Column(String(50))

    __mapper_args__ = {
        'polymorphic_identity':'employee',
        'polymorphic_on':type
    }
    
class Engineer(Employee):
    __tablename__ = 'engineer'
    id = Column(Integer, ForeignKey('employee.id'), primary_key=True)
    engineer_name = Column(String(30))

    __mapper_args__ = {
        'polymorphic_identity':'engineer',
    }

class Manager(Employee):
    __tablename__ = 'manager'
    id = Column(Integer, ForeignKey('employee.id'), primary_key=True)
    manager_name = Column(String(30))

    __mapper_args__ = {
        'polymorphic_identity':'manager',
    }    

如上有 员工、工程师、管理者 3 个表。

e = Employee.query.filter(xxx=xxx).first()

我想给 e 加上 Manager 和 Engineer 的角色应该如何表达?

就是一个员工可以有多种角色。

2186 次点击
所在节点    Python
4 条回复
qwer1234asdf
2016-11-23 17:24:27 +08:00
表本身就建的有问题
weyou
2016-11-23 18:06:54 +08:00
就不该拆表,加一个 role 字段,然后关联到 role 表
ryd994
2016-11-24 04:17:35 +08:00
学好范式………
tanywei
2016-11-24 09:58:15 +08:00
看官方文档想到的而已,谢谢大家。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/312257

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX