Alembic --autogenerate producing empty migration
我正在尝试首次使用
我的项目结构如下
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | project/ configuration/ __init__.py dev.py test.py core/ app/ models/ __init__.py user.py db/ alembic/ versions/ env.py alembic.ini |
我正在使用
1 2 3 4 5 6 7 8 9 10 11 | class User(UserMixin, db.Model): __tablename__ = 'users' # noinspection PyShadowingBuiltins uuid = Column('uuid', GUID(), default=uuid.uuid4, primary_key=True, unique=True) email = Column('email', String, nullable=False, unique=True) _password = Column('password', String, nullable=False) created_on = Column('created_on', sa.types.DateTime(timezone=True), default=datetime.utcnow()) last_login = Column('last_login', sa.types.DateTime(timezone=True), onupdate=datetime.utcnow()) |
如此处所述,我将
1 2 3 4 5 6 7 8 | from configuration import app alembic_config = config.get_section(config.config_ini_section) alembic_config['sqlalchemy.url'] = app.config['SQLALCHEMY_DATABASE_URI'] engine = engine_from_config( alembic_config, prefix='sqlalchemy.', poolclass=pool.NullPool) |
和
1 2 3 4 | from configuration import db target_metadata = db.metadata |
其中
1 2 3 4 5 6 7 8 | from flask import Flask from flask.ext.sqlalchemy import SQLAlchemy import dev app = Flask(__name__) app.config.from_envvar('SETTINGS_PT') db = SQLAlchemy(app) |
现在当我运行迁移时
1 2 3 4 5 | $alembic revision --autogenerate -m"Added user table" INFO [alembic.migration] Context impl PostgresqlImpl. INFO [alembic.migration] Will assume transactional DDL. Generating /Users/me/IdeaProjects/project/db/alembic/versions/55a9d5 35d8ae_added_user_table.py...done |
但是文件
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 | """Added user table Revision ID: 1b62a62eef0d Revises: None Create Date: 2013-03-27 06:37:08.314177 """ # revision identifiers, used by Alembic. revision = '1b62a62eef0d' down_revision = None from alembic import op import sqlalchemy as sa def upgrade(): ### commands auto generated by Alembic - please adjust! ### pass ### end Alembic commands ### def downgrade(): ### commands auto generated by Alembic - please adjust! ### pass ### end Alembic commands ### |
为什么不能理解有一个新的
请帮助
根据@zzzeek,在我将
下
1 2 3 4 5 6 7 8 9 | from configuration import app from core.expense.models import user # added my model here alembic_config = config.get_section(config.config_ini_section) alembic_config['sqlalchemy.url'] = app.config['SQLALCHEMY_DATABASE_URI'] engine = engine_from_config( alembic_config, prefix='sqlalchemy.', poolclass=pool.NullPool) |
然后我跑
1 2 3 4 5 6 7 8 9 10 11 12 13 | def upgrade(): ### commands auto generated by Alembic - please adjust! ### op.create_table('users', sa.Column('uuid', sa.GUID(), nullable=False), sa.Column('email', sa.String(), nullable=False), sa.Column('password', sa.String(), nullable=False), sa.Column('created_on', sa.DateTime(timezone=True), nullable=True), sa.Column('last_login', sa.DateTime(timezone=True), nullable=True), sa.PrimaryKeyConstraint('uuid'), sa.UniqueConstraint('email'), sa.UniqueConstraint('uuid') ) ### end Alembic commands ### |
谢谢迈克尔的所有帮助!
我想在这里指出当前版本(0.8.4)中存在相同的问题,但是设置元数据的方法似乎变得更加明确:除了导入模型之外,您还需要设置
文档建议导入他们称为
但是,代码中的实际注释建议使用实际模型(
如果您不希望flake8抛出未使用的导入错误,则还可以将记录添加到模型文件中的
在users.py
结尾
1 | __all__ = Users |
更多信息-https://docs.python.org/3/tutorial/modules.html#importing-from-a-package