为什么我会收到 SQLAlchemy 错误“__table_args__ 值必须是元组、字典或 None”

Why am I getting SQLAlchemy Error "__table_args__ value must be a tuple, dict, or None"

我有以下 SQLAlchemy 模型。已成功迁移至数据库:

class MyClassA(db.Model, Timestamp):
    a_id = db.Column(db.Integer, nullable=False, primary_key=True)
    b_id = db.Column(db.Integer, db.ForeignKey(C.c_id), nullable=False)
    d = db.Column(db.String(1024))
    e_id = db.Column(db.Integer,
                      db.ForeignKey(e.e_id))

现在我想在第二个和第四个字段之间添加唯一性约束。所以我将以下行添加到模型中:

     __table_args__ = db.UniqueConstraint('b_id', 'e_id', name='unique_constraint_bid_eid')

但是现在当我尝试迁移它时,出现以下错误:

sqlalchemy.exc.ArgumentError: __table_args__ value must be a tuple, dict, or None

为什么会出现此错误?我该如何解决?我尝试将等式的右边放在括号中,但这并没有解决问题。

如错误代码所示,

table_args 应该是元组、字典或 None。如果你把它变成一个元组,那么你必须把你的值放在括号里,最后还有一个逗号:

尝试:

     __table_args__ = (db.UniqueConstraint('b_id', 'e_id', name='unique_constraint_bid_eid'), )

参考这个Table Configuration

使用 table_args class 属性指定

Table 名称、元数据和映射列参数以外的参数。此属性包含通常发送到 Table 构造函数的位置参数和关键字参数。该属性可以用两种形式之一指定。一个是字典:

class MyClass(Base):
    __tablename__ = 'sometable'
    __table_args__ = {'mysql_engine':'InnoDB'}
    enter code here

另一个,一个元组,其中每个参数都是位置的(通常是约束):

class MyClass(Base):
    __tablename__ = 'sometable'
    __table_args__ = (
            ForeignKeyConstraint(['id'], ['remote_table.id']),
            UniqueConstraint('foo'),
            )

可以通过将最后一个参数指定为字典来使用上述形式指定关键字参数:

class MyClass(Base):
    __tablename__ = 'sometable'
    __table_args__ = (
            ForeignKeyConstraint(['id'], ['remote_table.id']),
            UniqueConstraint('foo'),
            {'autoload':True}
            )