iOS Как искать данные в нескольких таблицах данных Parse swift 4 - PullRequest
0 голосов
/ 08 сентября 2018

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

И я хочу сделать поиск из нескольких таблиц базы данных.

Для поиска я использую следующий код:

var searchResult = [String]()

func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
    return searchResult.count
}


func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
    let cell = tableView.dequeueReusableCell(withIdentifier: "cell", for: indexPath)

    cell.textLabel?.text = searchResult[indexPath.row]


    return cell
}

Для поиска в баре этот код:

 func searchBarSearchButtonClicked(_ searchBar: UISearchBar) {
    searchBar.resignFirstResponder()

    let firstQuery = PFQuery(className: "fried")
    firstQuery.whereKey("best", contains: searchBar.text)

    let seccondQuery = PFQuery(className: "home")
    seccondQuery.whereKey("home", contains: searchBar.text)

    let query = PFQuery.orQuery(withSubqueries: [firstQuery,seccondQuery])
    query.findObjectsInBackground { (result, error) in
        if let objects = result {
            self.searchResult.removeAll(keepingCapacity: false)

            for object in objects {
                let question = object.object(forKey: "question") as! String
                let answer = object.object(forKey: "answer1") as! String
                let test = question + " " + answer

                self.searchResult.append(test)
            }

            DispatchQueue.main.async {
                self.tableView.reloadData()
                self.resignFirstResponder()
            }

        }
    }

}

И я получил этот тип ошибки:

причина: 'Все подзапросы запроса or должны принадлежать одному и тому же классу.'

Можно сделать поиск по нескольким базам данных?

1 Ответ

0 голосов
/ 08 сентября 2018

Поиск по одному классу за раз, orQuery выполняется для подзапросов того же класса

self.searchResult.removeAll(keepingCapacity: false) // Start by emptying the search resulys array

firstQuery.findObjectsInBackground { (result, error) in
    if let objects = result {
        for object in objects {
            let question = object.object(forKey: "question") as! String
            let answer = object.object(forKey: "answer1") as! String
            let test = question + " " + answer
            self.searchResult.append(test)
        }

        DispatchQueue.main.async {
            self.tableView.reloadData()
            self.resignFirstResponder()
        }
    }
}

seccondQuery.findObjectsInBackground { (result, error) in
    if let objects = result {
        for object in objects {
            let question = object.object(forKey: "question") as! String
            let answer = object.object(forKey: "answer1") as! String
            let test = question + " " + answer
            self.searchResult.append(test)
        }

        DispatchQueue.main.async {
            self.tableView.reloadData()
            self.resignFirstResponder()
        }
    }
}

Или, что еще важнее:

let queryArry = [firstQuery, secondQuery]
for query in queryArray {
    query.findObjectsInBackground { (result, error) in
        if let objects = result {
            for object in objects {
                let question = object.object(forKey: "question") as! String
                let answer = object.object(forKey: "answer1") as! String
                let test = question + " " + answer
                self.searchResult.append(test)
            }

            DispatchQueue.main.async {
                self.tableView.reloadData()
                self.resignFirstResponder()
            }
        }
    }

}

...