gpt4 book ai didi

python - 使用 sqlalchemy_utils ChoiceType 在 Flask 中迁移时出错

转载 作者:太空宇宙 更新时间:2023-11-03 13:16:13 24 4
gpt4 key购买 nike

我有一个 Flask 模型:

class User(db.Model):
ROLE_USER = 0
ROLE_MODERATOR = 1
ROLE_ADMIN = 2
ROLES = [
(ROLE_USER, u'Regular user'),
(ROLE_MODERATOR, u'Moderator'),
(ROLE_ADMIN, u'Admin')
]

id = db.Column(db.Integer, primary_key = True)
login = db.Column(db.String(32), nullable=False, unique=True)
first_name = db.Column(db.String(32))
last_name = db.Column(db.String(32))
role = db.Column(ChoiceType(ROLES), nullable=False)

我用 flask-migrate 创建了一个迁移(数据库是 Postgresql):

def upgrade():
### commands auto generated by Alembic - please adjust! ###
op.create_table('user',
sa.Column('id', sa.Integer(), nullable=False),
sa.Column('login', sa.String(length=32), nullable=False),
sa.Column('first_name', sa.String(length=32), nullable=True),
sa.Column('last_name', sa.String(length=32), nullable=True),
sa.Column('role', sqlalchemy_utils.types.choice.ChoiceType(length=255), nullable=False),
sa.PrimaryKeyConstraint('id'),
sa.UniqueConstraint('login')
)

迁移已成功创建,但是当我要升级时,出现此错误:

TypeError: <flask_script.commands.Command object at 0x7fada1e973d0>: __init__() got an unexpected keyword argument 'length'

谁能解释一下这个问题?

最佳答案

如错误所述,ChoiceType 没有名为 length 的初始参数:

http://sqlalchemy-utils.readthedocs.org/en/latest/data_types.html#module-sqlalchemy_utils.types.choice

你可以删除它并使用

sqlalchemy_utils.types.choice.ChoiceType(User.ROLES)

相反。

关于python - 使用 sqlalchemy_utils ChoiceType 在 Flask 中迁移时出错,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29330578/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com