Получение реляционных пользователей из Parse - PullRequest
0 голосов
/ 24 апреля 2019

Я пытаюсь определить, связан ли текущий пользователь с моим событием.

Другими словами, у меня есть события, к которым пользователи могут присоединиться. Я храню PFRelation of User в таблице событий.

Я пытался

self.event.users.query().getObjectInBackground(withId: currentUser.objectId!, block: { (object, error) in
    if let error = error {
        //The query returned an error
        print(error.localizedDescription)
    } else {
        //The object has been retrieved
        print(object)
    }
})

и

do {
    let user = try self.event.users.query().getObjectWithId(currentUser.objectId!)

    if user == nil {
        currentUser.saveInBackground { (success: Bool, error: Error?) in
            eventsRelation.add(object)
        }

        usersRelation.add(currentUser)
        object.saveInBackground()


    }
} catch {
    print("Unexpected error: \(error).")
}

Но каждый из них возвращает пользователя, несмотря ни на что. Даже если они не в отношении.

Как будто они выполняют запрос для всей пользовательской таблицы.

Как мне запустить его только на моем подмножестве?

1 Ответ

0 голосов
/ 24 апреля 2019

Ответ заключается в использовании отношения для запроса.

Подробнее см. Здесь

Таким образом, код будет выглядеть так:

let usersRelation = event.relation(forKey: "users")

let usersRelationQuery = usersRelation.query()

usersRelationQuery.whereKey("objectId", equalTo: currentUser.objectId!)
usersRelationQuery.findObjectsInBackground(block: { (objects: [PFObject]?, error: Error?) in
    if let error = error {
        print(error.localizedDescription)
    } else if let objects = objects {
        // The find succeeded.
        print("Successfully retrieved \(objects.count) scores.")
        // Do something with the found objects
        for object in objects {
            print(object.objectId as Any)
        }
    }
})

Обратите внимание, что указанная выше переменная event взята из базы данных.

Если бы мы не включили часть whereKey, то она просто получит те, которые находятся в этих отношениях.

...