4

Miguel Grinberg の優れた Flask Mega-Tutorial に従い、彼のデータベース作成および移行スクリプト (ここにあります) を使用していますが、モデルの 1 つで列を変更するときに問題が発生します。

古いモデルは次のとおりです。

class Classes(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    day = db.Column(db.String(10))
    slot = db.Column(db.Integer)
    enrolments = db.relationship('Enrolment', backref='class_slot', lazy='dynamic')

    def __repr__(self):
        return '<Classes - %r slot %d>' % (self.day, self.slot)

class Enrolment(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    class_id = db.Column(db.Integer, db.ForeignKey('classes.id'))
    studentnum = db.Column(db.String(10), index=True, unique=True)
    name = db.Column(db.String(30))
    flags = db.Column(db.String(100))
    notes = db.Column(db.String(200))

    def __repr__(self):
        return '<Enrolment - (%r) %r>' % (self.name, self.studentnum)

classes.day は文字列表現です。ただし、これを外部キー関係にして、日ごとに簡単に検索およびソートできるようにしたいので、次のコードをモデルに追加しました。

class Days(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    day_name = db.Column(db.String(20), unique=True)
    classes = db.relationship('Classes', backref='dayofweek', lazy='select')

    def __repr__(self):
        return '<Day - %r>' % self.day_name

次に Classes モデルを変更し、day 列を次のように変更しました。

day = db.Column(db.Integer, db.ForeignKey('days.id'))

移行スクリプトを実行すると、モデルの生成時に次のエラーで停止します。

aaron$ ./db_migrate.py 
Traceback (most recent call last):
  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 "<string>", line 2, in make_update_script_for_model
  File "/Users/aaron/Dropbox/Development/put-attendance/flask/lib/python2.7/site-packages/migrate/versioning/util/__init__.py", line 90, in catch_known_errors
    return f(*a, **kw)
  File "<string>", line 2, in make_update_script_for_model
  File "/Users/aaron/Dropbox/Development/put-attendance/flask/lib/python2.7/site-packages/migrate/versioning/util/__init__.py", line 160, in with_engine
    return f(*a, **kw)
  File "/Users/aaron/Dropbox/Development/put-attendance/flask/lib/python2.7/site-packages/migrate/versioning/api.py", line 321, in make_update_script_for_model
    engine, oldmodel, model, repository, **opts)
  File "/Users/aaron/Dropbox/Development/put-attendance/flask/lib/python2.7/site-packages/migrate/versioning/script/py.py", line 70, in make_update_script_for_model
    genmodel.ModelGenerator(diff,engine).genB2AMigration()
  File "/Users/aaron/Dropbox/Development/put-attendance/flask/lib/python2.7/site-packages/migrate/versioning/genmodel.py", line 223, in genB2AMigration
    for modelCol, databaseCol, modelDecl, databaseDecl in td.columns_different:
ValueError: need more than 3 values to unpack

調べるtd.columns_differentと、リストに 1 つの項目 (文字列) しかないことがわかります'day'

データベースのフィールドのタイプを変更したために、なぜ窒息するのですか?

4

1 に答える 1

0

はい、td.columns_different は、以前のリビジョンと現在のリビジョンの間で変更された列の辞書です。このコードは sqlalchemy-migrate パッケージに属しています。

ソースからのコメント[1]:

class TableDiff(object):
  """
  ...

  ..attribute:: columns_different

  A dictionary containing information about columns that were
  found to be different.
  It maps column names to a :class:`ColDiff` objects describing the
  differences found.

列タイプを文字列から整数に移行するための解決策については、次を参照してください: sqlalchemy-migrate を使用して列タイプを可変文字から整数に変更する方法

[1] https://github.com/stackforge/sqlalchemy-migrate/blob/75034abe515a49e0efafb91519cfdf448ba02c73/migrate/versioning/schemadiff.py#L121

于 2015-01-27T21:40:52.083 に答える