0

我一直在尝试在两个表之间创建关联关系,intake并且module. 每个入口与模块具有一对多的关系。然而,每个模块都有一个课程作业,每个课程作业都有一个duedate对每个入学来说都是独一无二的。

我试过了,但没有用:

intake_modules_table = Table('tg_intakemodules',metadata,
   Column('intake_id',Integer,ForeignKey('tg_intake.intake_id',
                onupdate="CASCADE",ondelete="CASCADE")),
   Column('module_id',Integer,ForeignKey('tg_module.module_id',
                onupdate ="CASCADE",ondelete="CASCADE")),
   Column('dueddate', Unicode(16))
)

class Intake(DeclarativeBase):

    __tablename__ = 'tg_intake'

    #{ Columns
    intake_id = Column(Integer, autoincrement=True, primary_key=True)
    code = Column(Unicode(16))
    commencement = Column(DateTime)
    completion = Column(DateTime)

    #{ Special methods
    def __repr__(self):
        return '"%s"' %self.code
    def __unicode__(self):
        return self.code
    #}


class Module(DeclarativeBase):

    __tablename__ ='tg_module'

    #{ Columns
    module_id = Column(Integer, autoincrement=True, primary_key=True)
    code = Column(Unicode(16))
    title = Column(Unicode(30))

    #{ relations
    intakes = relation('Intake', 
        secondary=intake_modules_table, backref='modules')

    #{ Special methods
    def __repr__(self):
        return '"%s"'%self.title
    def __unicode__(self):
        return '"%s"'%self.title
    #}

当我这样做时,不会创建duedate中指定的列。intake_module_table请在这里提供一些帮助。

提前致谢

4

1 回答 1

0

实际上列duedate 创建,但在查询模型时您不会将其作为某些模型属性获取。我需要为intake_modules_table表定义中间模型并设置与它的关系,而不是Intake. 当然,对关系列的访问会更长一些(module.infakes[0].duedate, module.infakes[0].infake.code)。您也可以像现在一样设置关联代理来访问Infake对象列表。

于 2009-12-22T20:00:23.927 回答