Alembic - sqlalchemy не обнаруживает существующие таблицы

Я задал вопрос (Alembic - начальная миграция sqlalchemy) о том, как определять таблицы с помощью

target_metadata = Base.metadata

для

alembic revision --autogenerate -m "initial migration"

После того, как я импортировал свои модели в файл env.py, он работал нормально, но он не обнаруживает фактически существующие таблицы, поэтому он создает файл миграции со всеми таблицами, например:

def upgrade():
    ### commands auto generated by Alembic - please adjust! ###
    op.create_table('Brand',
    sa.Column('id', sa.Integer(), nullable=False),
    sa.Column('name', sa.String(), nullable=True),
    sa.Column('slug', sa.String(), nullable=True),
    sa.Column('date_created', sa.DateTime(), nullable=True),
    sa.Column('date_updated', sa.DateTime(), nullable=True),
    sa.PrimaryKeyConstraint('id'),
    schema='Products'
    )

def downgrade():
    ### commands auto generated by Alembic - please adjust! ###
    op.drop_table('ProductFile', schema='Products')

Я пробовал:

alembic stamp head

но после запуска этой команды и выполнения команды автогенерации система снова создает все модели.

from project.apps.users.models import *
from project.apps.orders.models import *
from project.apps.products.models import *

from project.base import Base, metadata

# this is the Alembic Config object, which provides
# access to the values within the .ini file in use.
config = context.config

# Interpret the config file for Python logging.
# This line sets up loggers basically.
fileConfig(config.config_file_name)

# add your model MetaData object here
# for 'autogenerate' support
# from myapp import mymodel
target_metadata = Base.metadata

Как избежать этой проблемы?

Edit:

ENV.py:

https://gist.github.com/pypetey/bb65807ce773d8baeaf1

Я сбросил db и выполнил миграцию

(env) D:\projekty\test>alembic revision --autogenerate
INFO  [alembic.migration] Context impl MSSQLImpl.
INFO  [alembic.migration] Will assume transactional DDL.
INFO  [alembic.autogenerate.compare] Detected added table u'Users.Country'
INFO  [alembic.autogenerate.compare] Detected added table u'Products.Brand'
INFO  [alembic.autogenerate.compare] Detected added table u'Users.User'
INFO  [alembic.autogenerate.compare] Detected added table u'Products.Product'
INFO  [alembic.autogenerate.compare] Detected added table u'Products.ProductFile
'
INFO  [alembic.autogenerate.compare] Detected added table u'Orders.Order'
INFO  [alembic.autogenerate.compare] Detected added table u'Products.Category'
INFO  [alembic.autogenerate.compare] Detected added table u'Products.Review'
INFO  [alembic.autogenerate.compare] Detected added table u'Users.UserAddress'
INFO  [alembic.autogenerate.compare] Detected added table u'Orders.OrderItem'
INFO  [alembic.autogenerate.compare] Detected added table u'Orders.OrderStatus'
Generating D:\projekty\test\alembic\versions\1c6337c144a7_.py ... done

(env) D:\projekty\test>alembic upgrade head
INFO  [alembic.migration] Context impl MSSQLImpl.
INFO  [alembic.migration] Will assume transactional DDL.
INFO  [alembic.migration] Running upgrade None -> 1c6337c144a7, empty message

(env) D:\projekty\test>alembic revision --autogenerate
INFO  [alembic.migration] Context impl MSSQLImpl.
INFO  [alembic.migration] Will assume transactional DDL.
INFO  [alembic.autogenerate.compare] Detected added table u'Users.Country'
INFO  [alembic.autogenerate.compare] Detected added table u'Products.Brand'
INFO  [alembic.autogenerate.compare] Detected added table u'Users.User'
INFO  [alembic.autogenerate.compare] Detected added table u'Products.Product'
INFO  [alembic.autogenerate.compare] Detected added table u'Products.ProductFile
'
INFO  [alembic.autogenerate.compare] Detected added table u'Orders.Order'
INFO  [alembic.autogenerate.compare] Detected added table u'Products.Category'
INFO  [alembic.autogenerate.compare] Detected added table u'Products.Review'
INFO  [alembic.autogenerate.compare] Detected added table u'Users.UserAddress'
INFO  [alembic.autogenerate.compare] Detected added table u'Orders.OrderItem'
INFO  [alembic.autogenerate.compare] Detected added table u'Orders.OrderStatus'
Generating D:\projekty\test\alembic\versions\5abb204549f_.py ... done

Ответ 1

У меня была такая же проблема - я не знаю, влияет ли это на вас. Для меня проблема была вызвана тем, что используемая мной схема не была дефолтом - я думаю, что то же самое происходит для вас, так как вы используете схему "Продукты". Я отправил сообщение по адресу:

https://bitbucket.org/zzzeek/alembic/issue/281/autogenerate-fails-to-detect-existing

И с небольшим количеством инструкций удалось решить проблему, установив include_schemas=True в функции run_migrations_* в модуле alembic/env.py.

Смотрите docs:

Если True, автогенерация сканирует все схемы, расположенные SQLAlchemy get_schema_names() и укажите все различия в таблицы, найденные во всех этих схемах. При использовании этой опции вы можете хотите также использовать EnvironmentContext.configure.include_objectвозможность указать вызываемый, который может фильтровать таблицы/схемы, которые включите.