db_migrate.py 884 B

123456789101112131415
  1. #!/usr/bin/env python2
  2. import imp
  3. from migrate.versioning import api
  4. from flask_app import db, config
  5. migration = config['SQLALCHEMY_MIGRATE_REPO'] + '/versions/%03d_migration.py' % (api.db_version(config['SQLALCHEMY_DATABASE_URI'], config['SQLALCHEMY_MIGRATE_REPO']) + 1)
  6. tmp_module = imp.new_module('old_model')
  7. old_model = api.create_model(config['SQLALCHEMY_DATABASE_URI'], config['SQLALCHEMY_MIGRATE_REPO'])
  8. exec old_model in tmp_module.__dict__
  9. script = api.make_update_script_for_model(config['SQLALCHEMY_DATABASE_URI'], config['SQLALCHEMY_MIGRATE_REPO'], tmp_module.meta, db.metadata)
  10. open(migration, "wt").write(script)
  11. api.upgrade(config['SQLALCHEMY_DATABASE_URI'], config['SQLALCHEMY_MIGRATE_REPO'])
  12. print 'New migration saved as ' + migration
  13. print 'Current database version: ' + str(api.db_version(config['SQLALCHEMY_DATABASE_URI'], config['SQLALCHEMY_MIGRATE_REPO']))