当前位置: 首页 > 知识库问答 >
问题:

组件自动生成不检测当前状态

颜霖
2023-03-14

我正在使用Alembic自动生成来迁移一些模型更改。我运行alembic修订/升级一次,它会正确创建我的表并将alembic_version表添加到我的数据库中。当我再次运行修订/升级命令时,它会尝试重新创建表,尽管没有对模型进行任何更改

alembic.command.revision(cfg, autogenerate=True)
INFO  [alembic.runtime.migration] Context impl PostgresqlImpl.
INFO  [alembic.runtime.migration] Will assume transactional DDL.
INFO  [alembic.autogenerate.compare] Detected added table 'alias.alias'

正如您在这里看到的,它正在尝试添加表alias.alias尽管它已经存在于我的数据库中,并且是由Alembic在第一个修订/升级命令中创建的。

可以预见,当我尝试运行第二次升级时,我得到了错误

psycopg2.errors.DuplicateTable: relation "alias" already exists

环境。py公司

import sys
import os
sys.path.insert(0, '/tmp/')

from logging.config import fileConfig
from sqlalchemy import engine_from_config
from sqlalchemy import pool
from alembic import context
from models.Base import Base
from models import Alias

config = context.config

fileConfig(config.config_file_name)

target_metadata = Base.metadata

def run_migrations_offline():
    """Run migrations in 'offline' mode.

    This configures the context with just a URL
    and not an Engine, though an Engine is acceptable
    here as well.  By skipping the Engine creation
    we don't even need a DBAPI to be available.

    Calls to context.execute() here emit the given string to the
    script output.

    """
    url = config.get_main_option("sqlalchemy.url")
    context.configure(
        url=url,
        target_metadata=target_metadata,
        literal_binds=True,
        dialect_opts={"paramstyle": "named"},
    )

    with context.begin_transaction():
        context.run_migrations()


def run_migrations_online():
    """Run migrations in 'online' mode.

    In this scenario we need to create an Engine
    and associate a connection with the context.

    """
    connectable = engine_from_config(
        config.get_section(config.config_ini_section),
        prefix="sqlalchemy.",
        poolclass=pool.NullPool,
    )

    with connectable.connect() as connection:
        context.configure(
            connection=connection, target_metadata=target_metadata
        )

        with context.begin_transaction():
            context.run_migrations()


if context.is_offline_mode():
    run_migrations_offline()
else:
    run_migrations_online()

别名py公司

from sqlalchemy import Column, Integer, String
from models.Base import Base


class Alias(Base):
    __tablename__ = 'alias'
    __table_args__ = {'schema': 'alias'}

    id = Column(Integer, primary_key=True)
    chart_config = Column(String)
    name = Column(String, nullable=False, unique=True)
    display_name = Column(String)
    datasets = Column(String)

基础py公司

from sqlalchemy.ext.declarative import declarative_base
Base = declarative_base()

如何让alembic检测到alias.alias表已经存在?它应该自动生成一个空修订。模型Alias.py在我的2次修订/升级运行期间是完全静态的

共有1个答案

饶高雅
2023-03-14

通过编辑alembic的env解决了这个问题。py将包含模式

    with connectable.connect() as connection:
    context.configure(
        connection=connection, target_metadata=target_metadata,
        include_schemas = True # Include this
    )

    with context.begin_transaction():
        context.run_migrations()
 类似资料:
  • Hibernate 的用户曾要求一个既可自动分配新持久化标识(identifier)保存瞬时(transient)对象,又可更新/重新关联脱管(detached)实例的通用方法。saveOrUpdate() 方法实现了这个功能。 // in the first session Cat cat = (Cat) firstSession.load(Cat.class, catID); // in a

  • 我已经为我的测试自动化套件在TFS上建立了一个构建。它有3个任务-Nuget还原、解决方案构建和VSTest任务。在我的测试中,我创建了一个新的ChromeDriver实例,并在我的解决方案上安装了ChromeWebDriveNuget。这在当地工作得很好。然而,TFS构建抛出了一个错误: OpenQA。硒。DriverServiceNotFoundException:文件c:\chromedri

  • 问题内容: 有什么工具可以自动生成 Java 代码的单元测试? 更新: 主要用途是为将要重构的遗留代码快速生成单元测试。自动生成后,无需自动使测试与代码保持同步。 在这里提出了几乎相同的问题,但是答案是.NET而不是Java(Pex是公认的答案): 问题答案: CodePro Analytix有一个JUnit测试生成模块,听起来像它可以完成您想要的。请参阅《用户指南》。 [CoView]是价格合理

  • 问题内容: 在我的詹金斯上,我配置了: 源代码管理 Git存储库:https : //bitbucket.org/username/project.git 凭据:用户名/密码 建造者触发器 将更改推送到BitBucket时生成 在我的BitBucket Webhooks上: http://Jenkins.URL:8080 / bitbucket-hook 我尝试将小的更改推送到.txt文件,但是J

  • 脚本例子一: !include "MUI.nsh" OutFile "S32.exe" !define MUI_PAGE_CUSTOMFUNCTION_PRE ComponentsPage1Pre !insertmacro MUI_PAGE_COMPONENTS Sectiongroup "完整独立程序" SecOL3 Section /o "QQ直播程序" Sec60 Sectio

  • 我正试图用我的MERN stack web应用程序自动化构建过程。 目前,我使用CodePipeline,它: 从GitHub获取我的代码作为源代码 使用CodeBuild(Ubuntu 2.0)运行构建 并将其部署到我的Elastic BeanStalk环境中 步骤1 在尝试使用CodeBuild之后,即使客户端似乎完全按照日志进行构建,前端似乎也不会更新。 以下是我CodeBuild项目的一些