Alembic自动生成空迁移文件

时间:2020-07-15 15:08:44

标签: sqlalchemy alembic fastapi starlette

我正在尝试将alembic库连接到databasessqlalchemy库。作为指导,我使用此示例link

我的项目文件:

db.py

from databases import Database
from sqlalchemy import MetaData, create_engine

DATABASE_URL = "postgresql://....@localhost:5432/db"

engine = create_engine(DATABASE_URL)
metadata = MetaData()

database = Database(DATABASE_URL)

models.py

from sqlalchemy import Table, Column, Integer, String, DateTime
from sqlalchemy.sql import func

from db import metadata

notes = Table(
    "notes",
    metadata,
    Column("id", Integer, primary_key=True),
    Column("title", String(50)),
    Column("description", String(50)),
    Column("created_date", DateTime, default=func.now(), nullable=False),
)

env.py (标签设置)

from db import DATABASE_URL, metadata

....
#add new
target_metadata = metadata
...
#change
def run_migrations_online():

    config.set_main_option('sqlalchemy.url', str(DATABASE_URL))
    connectable = engine_from_config(
        config.get_section(config.config_ini_section),
        prefix="sqlalchemy.",
        poolclass=pool.NullPool,
    )

我跑步时

alembic revision --autogenerate -m 'Add notest table'

在创建此上下文的迁移/版本时的新文件

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 ###

我想这可能与target_metadata =元数据变量的使用有关。看来这完全是按照指示进行的,但是迁移无法按预期进行。

1 个答案:

答案 0 :(得分:2)

如果有人有类似问题。您要做的就是将表从models.py导入到metadata对象之前的env.py文件中。

env.py

...
from models.notes import notes
from db import DATABASE_URL, metadata
...

我不知道为什么会起作用,但是会起作用。