如何用两个查询填充一个UITableView?

时间:2015-06-24 14:45:12

标签: ios swift uitableview parse-platform

我有一个tableview,需要显示用户参与的所有好友请求(发送和接收)。

但是,我能想到的唯一方法是执行两个单独的查询:一个用户名等于请求者,另一个用户名等于请求者。

这是最好的路线吗?如果是这样,我该如何设置代码?

我的代码一直在func cellForRowAtIndexPath() let dateString3 = timePeriodFormatter.stringFromDate(pendingDates[indexPath.row])上的应用程序崩溃,说明阵列超出了范围。

这是我到目前为止所做的:

@IBOutlet weak var tableView: UITableView!

override func viewWillAppear(animated: Bool) {

    UIApplication.sharedApplication().beginIgnoringInteractionEvents()

    users = []
    user = PFUser()
    objectId = String()
    pendingDates = []
    username = String()
    usernames = []
    tradeIdentifier = String()
    tradeId = []
    pendingRequestsId = []

    var requestsQuery = PFQuery(className: "Requests")
    requestsQuery.whereKey("status", equalTo: "transit")
    requestsQuery.whereKey("completed", notEqualTo: PFUser.currentUser()!.username!)
    requestsQuery.whereKey("completed", notEqualTo: "complete")
    requestsQuery.whereKey("requestedUsername", equalTo: PFUser.currentUser()!.username!)
    requestsQuery.orderByDescending("createdAt")
    requestsQuery.findObjectsInBackgroundWithBlock {
        (objects: [AnyObject]?, error: NSError?) -> Void in
        if error == nil {
            if let objects = objects as? [PFObject] {
                for object in objects {
                    pendingDates.append(object.createdAt! as NSDate)
                    usernames.append(object["requesterUsername"] as! String)
                    users.append(object["requester"] as! PFUser)
                    pendingRequestsId.append(object.objectId!)
                    tradeId.append("requested")
                }
            }
            var requestsQuery2 = PFQuery(className: "Requests")
            requestsQuery2.whereKey("status", equalTo: "transit")
            requestsQuery2.whereKey("completed", notEqualTo: PFUser.currentUser()!.username!)
            requestsQuery2.whereKey("completed", notEqualTo: "complete")
            requestsQuery2.whereKey("requesterUsername", equalTo: PFUser.currentUser()!.username!)
            requestsQuery2.orderByDescending("createdAt")
            requestsQuery2.findObjectsInBackgroundWithBlock {
                (objects: [AnyObject]?, error: NSError?) -> Void in
                if error == nil {
                    if let objects = objects as? [PFObject] {
                        for object in objects {
                            pendingDates.append(object.createdAt! as NSDate)
                            usernames.append(object["requestedUsername"] as! String)
                            users.append(object["requested"] as! PFUser)
                            pendingRequestsId.append(object.objectId!)
                            tradeId.append("requester")

                        }
                    }
                    UIApplication.sharedApplication().endIgnoringInteractionEvents()
                } else {
                    UIApplication.sharedApplication().endIgnoringInteractionEvents()
                    println(error)
                }
                //self.tableView.reloadData()
            }
        } else {
            println(error)
        }
        self.tableView.reloadData()
    }


}

func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {

    return usernames.count

}

func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {

    let cell: PendingTableViewCell = tableView.dequeueReusableCellWithIdentifier("cell", forIndexPath: indexPath) as! PendingTableViewCell

    cell.username.text = usernames[indexPath.row] as String

    let timePeriodFormatter = NSDateFormatter()
    timePeriodFormatter.dateFormat = "EEE, MMM d"

    let dateString3 = timePeriodFormatter.stringFromDate(pendingDates[indexPath.row])

    cell.date.text = dateString3

    return cell

}

func tableView(tableView: UITableView, didSelectRowAtIndexPath indexPath: NSIndexPath) {
    username = usernames[indexPath.row]
    objectId = pendingRequestsId[indexPath.row] as String
    tradeIdentifier = tradeId[indexPath.row]
    user = users[indexPath.row]
    self.performSegueWithIdentifier("showDetails", sender: self)        
}

1 个答案:

答案 0 :(得分:2)

我完全忘记了语法是什么,因为自从我使用解析以来已经有一段时间了,但我在我构建的应用程序中有类似的功能。 Parse允许您单独创建两个查询,然后在调用之前将它们连接在一起,以便返回两个单独查询的结果。

由于您尝试运行的查询属于同一个类,因此可以执行以下操作:

var requestQuery1 = PFQuery(className: "Requests")
requestQuery1.whereKey("status", equalTo: "Transit")
//add other query paremeter here
var requestQuery2 = PFQuery(className: "Requests)
//add query paremeters

然后在这里你可以同时运行两个查询:

var joinQuery = PFQuery.orQueryWithSubqueries([requestQuery1, requestQuery2])