SQLAlchemy(Flask)迁移数据库导致“解压缩的值太多”错误

时间:2016-01-28 16:50:51

标签: python flask

我已经完成了其他类似的线程,但它们并没有太相关。

当我添加密码字段时出现问题,如下所示:

class User(UserMixin, db.Model):
__tablename__ = 'user'    
id = db.Column(db.Integer, primary_key=True)
email = db.Column(db.String(120), index=True, unique=True)
about_me = db.Column(db.String(140))
last_seen = db.Column(db.DateTime)
password=db.Column(PasswordType(schemes=['pbkdf2_sha512','md5_crypt'],deprecated=['md5_crypt']))   

创建数据库很顺利,但是当我尝试将表迁移到其中时,我收到以下错误:

  File "db_migrate.py", line 12, in <module>
  script = api.make_update_script_for_model(SQLALCHEMY_DATABASE_URI, SQLALCHEMY_MIGRATE_REPO, tmp_module.meta, db.metadata)
  File "<decorator-gen-13>", line 2, in make_update_script_for_model
  File "/home/dale/anaconda3/envs/suggester/lib/python3.5/site-packages/migrate/versioning/util/__init__.py", line 90, in catch_known_errors
  return f(*a, **kw)
  File "<decorator-gen-12>", line 2, in make_update_script_for_model
  File "/home/dale/anaconda3/envs/suggester/lib/python3.5/site-packages/migrate/versioning/util/__init__.py", line 160, in with_engine
return f(*a, **kw)
  File "/home/dale/anaconda3/envs/suggester/lib/python3.5/site-packages/migrate/versioning/api.py", line 321, in make_update_script_for_model
engine, oldmodel, model, repository, **opts)
  File "/home/dale/anaconda3/envs/suggester/lib/python3.5/site-packages/migrate/versioning/script/py.py", line 70, in make_update_script_for_model
genmodel.ModelGenerator(diff,engine).genB2AMigration()
  File "/home/dale/anaconda3/envs/suggester/lib/python3.5/site-packages/migrate/versioning/genmodel.py", line 219, in genB2AMigration
 for modelCol, databaseCol, modelDecl, databaseDecl in td.columns_different:
  ValueError: too many values to unpack (expected 4)

任何建议都将不胜感激。

更多详情:

PasswordTypesqlachemy-utils class。我只是复制并粘贴它,所以我认为这个问题至少与实现无关。

我也在使用Miguel的db_migrate文件,这对我来说已经很好了:

#!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, 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))

0 个答案:

没有答案