簡體   English   中英

Vapor 4,如何按外鍵過濾?

[英]Vapor 4, How to filter by Foreign Key?

我有兩個模型(UserModel 和 UserTokenModel)

UserTokenModel 有一個表示 UserModel 的 ForeignKey。

這是我的代碼。 我嘗試在 UserTokenModel 上按 userModel 的 ID 進行過濾,但出現錯誤。

運算符函數“==”要求“UUID”符合“QueryableProperty”

if let user = try await UserModel.query(on: req.db).filter(\.$email == request.email).first() {
    //Compile Error: Operator function '==' requires that 'UUID' conform to 'QueryableProperty'
    let userToken = try await UserTokenModel.query(on: req.db)
    .filter(\.$user.id == user.$id).first()
}

這是模型的定義

final class UserModel: Model {
    static let schema = "user_users"
    
    struct FieldKeys {
        static var email: FieldKey { "email" }
        static var password: FieldKey { "password" }
        static var appleId: FieldKey { "appleId" }
        static var givenName: FieldKey { "givenName" }
        static var familyName: FieldKey { "familyName" }
        static var userName: FieldKey { "userName" }
    }
    
    //MARK:- fields
    @ID() var id: UUID?
    @Field(key: FieldKeys.email) var email: String
    @Field(key: FieldKeys.password) var password: String
    @Field(key: FieldKeys.appleId) var appleId: String?
    @Field(key: FieldKeys.givenName) var givenName: String?
    @Field(key: FieldKeys.familyName) var familyName: String?
    @Field(key: FieldKeys.userName) var userName: String?
    
    init() {}
    
    init(id: UserModel.IDValue? = nil,
         email: String,
         password: String,
         appleId: String? = nil,
         givenName: String? = nil,
         familyName: String? = nil,
         userName: String? = nil
    ) {
        self.id = id
        self.email = email
        self.password = password
        self.appleId = appleId
        self.givenName = givenName
        self.familyName = familyName
        self.userName = userName
    }
}

用戶令牌模型

final class UserTokenModel: Model {
    static let schema = "user_tokens"
    
    struct FieldKeys {
        static var value: FieldKey { "value" }
        static var userId: FieldKey { "user_id" }
    }
    
    //MARK:- fields
    
    @ID() var id: UUID?
    @Field(key: FieldKeys.value) var value: String
    @Parent(key: FieldKeys.userId) var user: UserModel
    
    init() {}
    init(
        id: UserTokenModel.IDValue? = nil,
        value: String,
        userId: UserModel.IDValue
    ) {
        self.id = id
        self.value = value
        $user.id = userId
    }
}

您需要將代碼更改為:

if let user = try await UserModel.query(on: req.db).filter(\.$email == request.email).first() {
    guard let userId = user.id
    else { throw SomeError() }
    //Compile Error: Operator function '==' requires that 'UUID' conform to 'QueryableProperty'
    let userToken = try await UserTokenModel.query(on: req.db)
    .filter(\.$user.$id == userId).first()
}

QueryableProperty錯誤是由於您沒有在過濾器的 LHS 中的id前面放入$ 如果你解決了這個問題,你會得到一個關於user.id屬性是Optional的錯誤。 引入守衛解決了這個問題,並允許您在用戶不存在時處理錯誤。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM