在同一选项卡中与SQLAlchemy的多对一关系

2024-05-18 19:55:56 发布

您现在位置:Python中文网/ 问答频道 /正文

我有一个“客户”表,其中一个客户可以是另一个客户的孩子。

这是表的定义。

[ClientID] [int] IDENTITY(1,1) NOT NULL,
[name] [varchar](50) NOT NULL,
[VPFSID] [varchar](50) NOT NULL,
[Type] [varchar](25) NULL,
[ROHostID] [varchar](60) NOT NULL,
[RWHostID] [varchar](60) NOT NULL,
[ParentClientID] [int] NULL

在SQLAlchemy中,如何创建ParentClientID和ClientID之间的关系。我使用声明式将这个类组合在一起,但我不确定它是否有效。一个客户可以有很多孩子,但只能有一个单亲,所以这是一种多对一的关系

class Client(Base):
    """ Client Filesystems """
    __tablename__ = 'Client'

    client_id = Column('ClientID', int, primary_key=True, nullable=Flase)
    name = Column('name', String(50), nullable=False)
    vpfs_id = Column('VPFSID', String(50), nullable=False)
    type = Column('Type',String(25))
    ro_host_id = Column('ROHostID', String(60), ForeignKey('DataMover.HostID'), nullable=False)
    rw_host_id = Column('RWHostID', String(60), ForeignKey('DataMover.HostID'), nullable=False)
    rw_host = relation('Datamover',backref="rw_clients")
    ro_host = relation('Datamover',backref="ro_clients")
    parent_client_id = Column('ParentClientID',int,ForeignKey('Client.ClientID'))
    parent = relation('Client',ForeignKey('Client.ClientID'))

有什么建议吗?


Tags: nameclientidfalsehoststring客户not

热门问题