【发布时间】:2021-08-06 10:06:28
【问题描述】:
我有 3 个表,LastName、MiddleName 和 FirstName,我想在 FirstName、MiddleName 中创建新记录或更新记录,前提是 lastName 存在。如果姓氏不存在,则想返回错误。
final class LastName: Model, Content {
static let schema = "lastnames"
@ID(key: .id)
var id: UUID?
@Field(key: "name")
var name: String
@Children(for: \.$lastname)
var middle_names: [MiddleName]
init() { }
init(id: UUID? = nil, name: String) {
self.id = id
self.name = name
}
}
final class MiddleName: Model, Content {
static let schema = "middlenames"
@ID(key: .id)
var id: UUID?
@Parent(key: "last_name_id")
var lastname: LastName
@Field(key: "name")
var name: String
@Children(for: \.$middleNameId)
var firstNames: [FirstName]
init() { }
init(id: UUID? = nil, lastname: LastName, name: String ) {
self.id = id
self.lastname = lastname
self.name = name
}
}
final class FirstName: Model, Content {
static let schema = "firstnames"
@ID(key: .id)
var id: UUID?
@Parent(key: "middle_name_id")
var middleNameId: MiddleName
@Field(key: "name")
var name: String
init() { }
init(id: UUID? = nil, middleNameId: MiddleName, name: String) {
self.id = id
self.middleNameId = testBundleId
self.name = name
}
}
Fluent 文档在通过嵌套连接创建新记录方面非常少,因为 ID 是在创建姓氏时自动生成的,我如何获取用于创建 MiddleName/FirstName 的 ID。还有什么好的例子可以根据关系在多个表中进行更新或创建?
基本上我想要流利地做类似的事情
LastName.query(on: req.db).filter(\.$name == "Smith")
.first()
.unwrap(or: Abort(.notFound))
// Now Find if middle name exists, if exists use the ID to create first name and maybe even update middle name table,
// if middle name does not exist, create middle name record, then use the new ID to create first name record
// return the new record(s) as some new Swift Codable DTO
【问题讨论】:
-
你真的需要这个 id 吗?您查询姓氏,然后在 middle_names 数组中搜索给定的中间名,并将名字附加到结果或新的 MiddleName 对象,该对象在保存之前插入到 middle_names 数组中。自从我使用 Fluent 和 Vapor 以来已经有一段时间了,但这应该是可能的。
-
@JoakimDanielson 我不需要身份证,对不起,我应该澄清一下..身份证或姓名,或者只是记录应该没问题..
标签: swift vapor vapor-fluent