在获取唯一要求并迁移

时间:2017-11-14 02:10:33

标签: python sqlalchemy

我在sqlite中创建了一个模型,其列名具有属性unique = True。后来我决定放弃这个属性,所以我将它改为unique = False但是我得到了以下错误,好像我从未做过更改。

错误:

IntegrityError: (sqlite3.IntegrityError) UNIQUE constraint failed: group.name [SQL: u'INSERT INTO "group" (name, timestamp, parent_id) VALUES (?, ?, ?)'] [parameters: (u'DOW', None, None)]

old model.py

class Group(db.Model):
    id=db.Column(db.Integer, primary_key=True)
    name=db.Column(db.String(32), nullable=False, unique=True)
    timestamp=db.Column(db.DateTime)
    permissions=db.relationship('Permission', backref='group')
    roles=db.relationship('Role', backref='group')
    messages=db.relationship('Message', backref='group')

    message_groups=db.relationship('Message_Group', backref='group')
    message_users=db.relationship('Message_User', backref='group')
    parent_id=db.Column(db.Integer, db.ForeignKey('group.id'))
    children=db.relationship('Group', backref=db.backref('parent', remote_side=[id]))
    #users backrefs User

new model.py

class Group(db.Model):
    id=db.Column(db.Integer, primary_key=True)
    name=db.Column(db.String(32), nullable=False, unique=False)
    timestamp=db.Column(db.DateTime)
    permissions=db.relationship('Permission', backref='group')
    roles=db.relationship('Role', backref='group')
    messages=db.relationship('Message', backref='group')

    message_groups=db.relationship('Message_Group', backref='group')
    message_users=db.relationship('Message_User', backref='group')
    parent_id=db.Column(db.Integer, db.ForeignKey('group.id'))
    children=db.relationship('Group', backref=db.backref('parent', remote_side=[id]))
    #users backrefs User

以下是我在更改名称

后用于升级数据库的迁移脚本

db_migrate.py

#!flask/bin/python
import imp
from migrate.versioning import api
from app import db
from config import SQLALCHEMY_DATABASE_URI
from config import SQLALCHEMY_MIGRATE_REPO
v = api.db_version(SQLALCHEMY_DATABASE_URI, SQLALCHEMY_MIGRATE_REPO)
migration = SQLALCHEMY_MIGRATE_REPO + ('/versions/%03d_migration.py' % (v+1))
tmp_module = imp.new_module('old_model')
old_model = api.create_model(SQLALCHEMY_DATABASE_URI, SQLALCHEMY_MIGRATE_REPO)
exec old_model in tmp_module.__dict__
script = api.make_update_script_for_model(SQLALCHEMY_DATABASE_URI,
                                          SQLALCHEMY_MIGRATE_REPO,
                                          tmp_module.meta, db.metadata)
open(migration, "wt").write(script)
api.upgrade(SQLALCHEMY_DATABASE_URI, SQLALCHEMY_MIGRATE_REPO)
v = api.db_version(SQLALCHEMY_DATABASE_URI, SQLALCHEMY_MIGRATE_REPO)
print('New migration saved as ' + migration)
print('Current database version: ' + str(v))

db_upgrade.py

#!flask/bin/python
from migrate.versioning import api
from config import SQLALCHEMY_DATABASE_URI
from config import SQLALCHEMY_MIGRATE_REPO
api.upgrade(SQLALCHEMY_DATABASE_URI, SQLALCHEMY_MIGRATE_REPO)
v = api.db_version(SQLALCHEMY_DATABASE_URI, SQLALCHEMY_MIGRATE_REPO)
print('Current database version: ' + str(v))

随意判断我的模型并提供提示以加快速度。我仍然是sql的新手。

0 个答案:

没有答案