首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >Alembic: IntegrityError:“添加不可为空的列时列包含空值”

Alembic: IntegrityError:“添加不可为空的列时列包含空值”
EN

Stack Overflow用户
提问于 2015-11-14 14:13:29
回答 1查看 22.1K关注 0票数 66

我正在向现有表中添加一列。这个新列是nullable=False

代码语言:javascript
复制
op.add_column('mytable', sa.Column('mycolumn', sa.String(), nullable=False))

当我运行迁移时,它会报错:

代码语言:javascript
复制
sqlalchemy.exc.IntegrityError: column "mycolumn" contains null values
EN

回答 1

Stack Overflow用户

发布于 2018-12-10 12:59:57

它正确地告诉您,数据库中存在(或将存在)该列的空值。答案是先编辑迁移文件以更新列,然后再更改列定义:

代码语言:javascript
复制
from sqlalchemy.sql import table, column

def upgrade():
    op.add_column('role', sa.Column('role_name', sa.String(length=30), nullable=True))
    role = table('role', column('role_name'))       
    op.execute(role.update().values(role_name=''))       
    op.alter_column('role', 'role_name', nullable=False)       
票数 11
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/33705697

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档