- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试使用 alembic 运行创建迁移 alembic revision --autogenerate -m 'initial setup'
但我收到错误:
FAILED: Can't proceed with --autogenerate option; environment script /Users/paul/python/my_project/alembic/env.py does not provide a MetaData object or sequence of objects to the context.
alembic current
创建数据库没有问题。
# A generic, single database configuration.
[alembic]
# path to migration scripts
script_location = alembic
# template used to generate migration files
# file_template = %%(rev)s_%%(slug)s
# timezone to use when rendering the date
# within the migration file as well as the filename.
# string value is passed to dateutil.tz.gettz()
# leave blank for localtime
# timezone =
# max length of characters to apply to the
# "slug" field
# truncate_slug_length = 40
# set to 'true' to run the environment during
# the 'revision' command, regardless of autogenerate
# revision_environment = false
# set to 'true' to allow .pyc and .pyo files without
# a source .py file to be detected as revisions in the
# versions/ directory
# sourceless = false
# version location specification; this defaults
# to alembic/versions. When using multiple version
# directories, initial revisions must be specified with --version-path
# version_locations = %(here)s/bar %(here)s/bat alembic/versions
# the output encoding used when revision files
# are written from script.py.mako
# output_encoding = utf-8
sqlalchemy.url = sqlite:///./src/db/data.sqlite
# Logging configuration
[loggers]
keys = root,sqlalchemy,alembic
[handlers]
keys = console
[formatters]
keys = generic
[logger_root]
level = WARN
handlers = console
qualname =
[logger_sqlalchemy]
level = WARN
handlers =
qualname = sqlalchemy.engine
[logger_alembic]
level = INFO
handlers =
qualname = alembic
[handler_console]
class = StreamHandler
args = (sys.stderr,)
level = NOTSET
formatter = generic
[formatter_generic]
format = %(levelname)-5.5s [%(name)s] %(message)s
datefmt = %H:%M:%S
import sys
from logging.config import fileConfig
from pathlib import Path
from sqlalchemy import engine_from_config
from sqlalchemy import pool
from alembic import context
folder = Path(__file__).resolve().parents[1]
sys.path.insert(0, str(folder))
import src.data.__all_models
from src.data.modelbase import SqlAlchemyBase
# 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's MetaData object here
# for 'autogenerate' support
# from myapp import mymodel
# target_metadata = mymodel.Base.metadata
target_metadata = SqlAlchemyBase.metadata
# other values from the config, defined by the needs of env.py,
# can be acquired:
# my_important_option = config.get_main_option("my_important_option")
# ... etc.
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
)
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()
import sqlalchemy.ext.declarative as dec
SqlAlchemyBase = dec.declarative_base()
target_metadata = SqlAlchemyBase.metadata
线。
最佳答案
结果证明问题出在我的编辑器上。我关闭了 env.py 文件,重新打开它,并按预期进行了所有更改。然后我决定看看如果我从控制台中的错误消息中通过命令+单击它来打开文件(我正在使用 VSCode),并且当我以这种方式打开它时我没有任何更改,看看会发生什么。我再次尝试从辅助文件资源管理器打开文件,我的更改在文件中,但 alembic 仍然无法运行。我完全关闭了 VSCode 并重新打开它,然后更改在我的文件中并且 alembic 运行没有问题。
我以前从未遇到过这个问题,所以我不知道 VSCode 发生了什么,但无论它重新启动它解决了问题。
关于python - Alembic SQLAlchemy 自动生成元数据错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57154376/
我正在尝试将我的 Flask 项目与 Alembic 我的应用程序结构看起来像 project/ configuration/ __init__.
我将 Alembic 与 SQLAlchemy 结合使用来执行模式迁移 和 data migration . 由于我在项目的主应用程序 myapp 中将特定于迁移的依赖项存储在它们自己的模块中(根据
这是已经发生和正在发生的事件链 第 0 天:我开发并部署了我的应用程序 第 1 天:我创建了新数据库 第 3 天:我意识到我想在现有表中添加一个新行。我找到了flask-migrate,我想用它来迁移
我正在尝试在 Alembic 上创建一个新的迁移,它将新枚举类型的新列添加到现有表中。但是我收到一个我认为 Alembic 会自动处理的错误。 我使用的是 Postgres 9.6.6、Alembic
我将 Alembic 与 SQLAlchemy 一起使用。使用 SQLAlchemy,我倾向于遵循不将连接字符串与版本化代码一起存储的模式。相反,我有包含任何 secret 信息的文件 secret.
背景 我正在尝试在此 Flask + RESTplus server example 中使用 PostgreSQL 后端而不是 Sqlite . 我遇到了 PasswordType 数据库列类型的问题
我在一个使用 alembic 管理数据库迁移的团队中工作。我最近拉了master,并尝试运行alembic upgrade heads .我收到以下消息; INFO [alembic.runtime
我想为 Flask 应用程序进行迁移。我正在使用 Alembic。 但是,我收到以下错误。 Target database is not up to date. 在线,我读到这与此有关。 http:/
我正在从事一个使用 SQLite 作为数据库并使用 Alembic 作为数据库迁移工具的项目。它包含空间数据,因此空间扩展和 geoalchemy2 包含在项目中。我正在使用 autogenerate
这个问题在这里已经有了答案: change column datatype from array to integer (2 个答案) 关闭 3 年前。 我有一个这样的模型: class Sched
当我想使用 alembic 进行自动生成迁移时出现错误。 项目树: - alembic.ini - axis.py - tree.txt - alembic - en
我正在使用 Alembic 来管理数据库的迁移。多个 Python 包使用同一个数据库,每个包都有自己的迁移路径。 在生成自动迁移时,如何告诉 Alembic 忽略其他包中的表?例如,当我运行时:
我有一个看起来像这样的表 > select * from mytable id value 0 1 hello world 1 2 hello_world 2 3 hel
我正在使用 alembic 根据用户定义的 sqlalchemy 模型管理数据库迁移。我的挑战是 我希望 alembic 忽略对特定表集的任何创建、删除或更改。 注:我的 Q 与这个问题类似 Igno
我有一个 SQLAlchemy 模型,例如 - class UserFavPlace(db.Model): # This model stores the feedback from the
我需要通过向现有表添加一张表和一列来更新我的数据库。 新列和表应该是一对多的关系。 这是 Alembic 修订文件: def upgrade(): op.create_table('categ
我有一个表 'test' 有一个没有约束的列 'Name'。我需要ALTER给它一个 UNIQUE约束。我该怎么做? 我应该使用 op.alter_column('???')或 create_uniq
我有下表 mysql> describe table; +----------------+-------------+------+-----+-------------------+-------
我最初将我的一个 SQLAlchemy 模型定义为: class StreetSegment(db.Model): id = db.Column(db.Integer, autoincreme
我正在使用 Flask-Migrate==2.0.0。它没有正确检测到变化。每次我运行 python manage db migrate 它都会为所有模型生成一个脚本,尽管它们已在以前的修订版中成功添
我是一名优秀的程序员,十分优秀!