4

Miguel Grinberg의 우수한 Flask Mega-Tutorial을 따르고 데이터베이스 생성 및 이전 스크립트 (here)를 사용하고 있지만 문제가 있습니다. 내 모델 중 하나에서 열을 변경할 때.Python/SQLAlchemy migration - ValueError : 마이그레이션 할 때 값을 3 개 이상 필요합니다.

오래된 모델이었다

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는 String 표현 인 상태. 그러나 나는 내가 쉽게 검색 할 수 및 종류 하루 외래 키 관계로이를 만들고 싶어, 그래서 모델에 다음 코드를 추가 :에 하루 열을 변경,

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 

다음 클래스 모델을 수정 : 다음 오류 모델을 생성 할 때

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 쇼를 검사하는 문자열에는 하나의 항목 만 있습니다. 문자열은 'day'입니다.

데이터베이스의 필드 유형을 변경했기 때문에 왜 질식합니까?

답변

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. 

: How to alter column type from character varying to integer using sqlalchemy-migrate

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

+0

감사합니다. 수동으로 업그레이드 스크립트를 작성하고 싶지 않았습니다. 마지막으로 sqlalchemy-migrate를 포기했습니다. SQLAlchemy의 최신 버전에서는 훌륭하게 작동하지 않는 것 같습니다. 나는 그 후 잘 작동하는 flask-migrate로 전환했다. 하지만 유용한 정보와 링크가 있기 때문에 답변을 수락 할 것입니다. 다른 솔루션으로 "이전"하는 것 외에는이 버그에 대한 수정을 기대하지 않습니다. –