- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在使用 PostgreSQL 和 Alembic 进行迁移。当我将新列添加到我的用户表时,Alembic 使用以下脚本生成了迁移:
revision = '4824acf75bf3'
down_revision = '2f0fbdd56de1'
from alembic import op
import sqlalchemy as sa
def upgrade():
op.add_column(
'user',
sa.Column(
'username',
sa.Unicode(length=255),
nullable=False
)
)
def downgrade():
op.drop_column('user', 'username')
我真正想做的是在升级生产版本时自动生成用户名的值。换句话说,我的生产版本里面有很多用户,如果我在上面运行上面的升级,会出现用户名不能为 NULL 的错误,所以我必须删除所有用户,升级用户表和再次添加用户后,这很痛苦。因此,我想将上面的脚本更改为:
revision = '4824acf75bf3'
down_revision = '2f0fbdd56de1'
from alembic import op
import sqlalchemy as sa
def upgrade():
op.add_column(
'user',
sa.Column(
'username',
sa.Unicode(length=255)
)
)
op.execute(
'UPDATE "user" set username = <email address with no '@'
and everything comes after '@' sign should be removed>
WHERE email is not null'
)
<only after the above code is executed 'nullable=False' must be set up>
def downgrade():
op.drop_column('user', 'username')
正如上面代码中所述,我想执行一个 SQL 代码来检查像 test@example.com 这样的电子邮件地址,并在“@”符号(在本例中为“@example.com”)之后抛出所有内容,并且在使 nullable=false 之后设置用户名的值(在本例中为“test”)。
我该怎么做?什么必须是脚本而不是 username = <email address with no '@' and everything comes after '@' sign should be removed>
和设置 nullable=false
或者如果有任何其他方式设置username
默认值为不带@sing 的电子邮件地址及其后的所有内容?
最佳答案
问题是这样解决的。
def upgrade():
op.add_column(
'user',
sa.Column(
'username',
sa.Unicode(length=255)
)
)
op.create_index('ix_user_username', 'user', ['username'], unique=True)
op.execute(
'''
DO
$do$
DECLARE uid INTEGER;
DECLARE username_candidate TEXT;
BEGIN
FOR uid, username_candidate IN (
SELECT
id,
lower(
substring(email for position('@' in email) - 1)
)
FROM "user" WHERE username is null
) LOOP
UPDATE "user"
SET username = username_candidate
WHERE
id = uid AND
NOT EXISTS (
SELECT id FROM "user" WHERE username = username_candidate
);
END LOOP;
END
$do$
'''
)
# Fix name colissions
op.execute(
'''
DO
$do$
DECLARE uniqufier INTEGER := 0;
DECLARE uid INTEGER;
DECLARE username_candidate TEXT;
BEGIN
WHILE EXISTS (SELECT id FROM "user" WHERE username is null) LOOP
uniqufier := uniqufier + 1;
FOR uid, username_candidate IN (
SELECT
id,
lower(
substring(email for position('@' in email) - 1)
|| uniqufier
)
FROM "user" WHERE username is null
) LOOP
UPDATE "user"
SET username = username_candidate
WHERE
id = uid AND
NOT EXISTS (
SELECT id FROM "user" WHERE username = username_candidate
);
END LOOP;
END LOOP;
END;
$do$
'''
)
op.alter_column(
'user',
'username',
nullable=False,
)
def downgrade():
op.drop_index('ix_user_username', table_name='user')
op.drop_column('user', 'username')
关于database - 使用 alembic 升级表时设置列的值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25403549/
我正在尝试将我的 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 它都会为所有模型生成一个脚本,尽管它们已在以前的修订版中成功添
我是一名优秀的程序员,十分优秀!