gpt4 book ai didi

swift - Vapor Fluent 如何向现有表添加新的必填字段键

转载 作者:行者123 更新时间:2023-12-03 08:13:53 25 4
gpt4 key购买 nike

我部署了一个使用 Vapor Fluent PostgreSQL 构建的后端。

现在,我需要将新的必需字段键 new_field 添加到数据库中架构名称 schema_name 的表中。我创建了一个新的迁移:

struct AddNewFieldToSchema: Migration {
func prepare(on database: Database) -> EventLoopFuture<Void> {
database.schema("schema_name")
.field("new_field", .string, .required)
.update()
}

func revert(on database: Database) -> EventLoopFuture<Void> {
database.schema("schema_name")
.deleteField("new_field")
.update()
}
}

但是运行后,它给了我错误:

Fatal error: Error raised at top level: server: column "new_field" of relation "schema_name" contains null values (ATRewriteTable)

我猜测这是因为使用旧数据模型创建的现有数据没有 new_field 值,因为如果数据库为空,此新迁移运行正常。

如何解决这个问题?谢谢。

最佳答案

.field 函数采用可选属性列表,您可以在其中传递默认值,因此对您来说它是

func prepare(on database: Database) -> EventLoopFuture<Void> {
database.schema("schema_name")
.field("new_field", .string, .required, .sql(.default("Your default value")))
.update()
}

关于swift - Vapor Fluent 如何向现有表添加新的必填字段键,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/70073796/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com