在查询中合并两个解析表

时间:2015-06-05 09:07:25

标签: ios swift parse-platform merging-data

我有两个解析类,一个是“用户”,另一个是用户输入一些评论,如“推文”。在“users”类中,每个对象都有两列,即用户名和照片。在tweets表中,每个对象都有用户名和注释的信息。我需要根据用户名匹配进行合并这两个表的查询,最后应该有3列,用户名 - 照片 - 评论。我怎么能通过swift在xcode中做到这一点?我将使用结果将其作为数组附加并在表视图单元格中显示它们。

3 个答案:

答案 0 :(得分:2)

你应该看一下Parse 1-many关系。 Here您可以找到基于Swift的代码段。

基本上,您不会通过关联用户名(这是SQL数据库中会发生的事情)将用户的推文链接到该用户。你所做的是为推文分配用户对象,然后当你有推文时,你可以访问它的用户属性及其所有属性。

let user = PFObject(className:"TweetAuthor")
...
let tweet = PFObject(className:"Tweet")
tweet["..."] = ...
tweet["createdBy"] = user
...
let userTweets = PFQuery(className:"Tweet")
tweetQuery.whereKey("createdBy", equalTo: user)
tweetQuery.findObjectsInBackgroundWithBlock {
      (objects: [AnyObject]?, error: NSError?) -> Void in

    let aTweet = object![...]
    let picture = aTweet["createdBy"]["picture"]
    ...
}

希望这有帮助。

编辑:

你应该如何使用上面的代码?

我认为,在您的应用中的某个位置,您创建了一条推文,并且您当前正在为其指定一个用户名' (以及' profilePicture'等):

tweet["userName"] = user["username"]

不是分配userName(字符串),而是为其分配完整的用户对象:

tweet["createdBy"] = user

(删除所有代码以分配profilePicture等)

完成此操作后,您可以通过以下方式获取与推文相关联的图片:

let picture = aTweet["createdBy"]["picture"]

答案 1 :(得分:0)

我使用的代码是当前用户所关注的人的信息,并显示他们的推文信息。然而,当用户更新他在用户表中的个人资料图片时,不更新推文表的过去数据(其还包括个人资料图片)。

func refreshResults(){

    followArray.removeAll(keepCapacity: false)
    resultsNameArray.removeAll(keepCapacity: false)
    resultsUserNameArray.removeAll(keepCapacity: false)
    resulltsImageFiles.removeAll(keepCapacity: false)
    resultsTweetArray.removeAll(keepCapacity: false)
    resultsHasImageArray.removeAll(keepCapacity: false)
    resultsTweetImageFiles.removeAll(keepCapacity: false)
    resultsTweetType.removeAll(keepCapacity: false)

    var followQuery = PFQuery(className: "follow")
    followQuery.whereKey("user", equalTo: PFUser.currentUser()!.username!)
    followQuery.addDescendingOrder("createdAt")

    var objects = followQuery.findObjects()

    for object in objects! {

        self.followArray.append(object.objectForKey("userToFollow") as! String)

    }

    var query = PFQuery(className: "tweets")
    query.whereKey("userName", containedIn: followArray)
    query.addDescendingOrder("createdAt")

    query.findObjectsInBackgroundWithBlock {
        (objects:[AnyObject]?, error:NSError?) -> Void in

        if error == nil {

            for object in objects! {

                self.resultsNameArray.append(object.objectForKey("profileName") as! String)
                self.resultsUserNameArray.append(object.objectForKey("userName") as! String)
                self.resulltsImageFiles.append(object.objectForKey("photo") as! PFFile)
                self.resultsTweetArray.append(object.objectForKey("tweet") as! String)
                self.resultsHasImageArray.append(object.objectForKey("hasImage") as! String)
                self.resultsTweetImageFiles.append(object.objectForKey("tweetImage") as? PFFile)
                self.resultsTweetType.append(object.objectForKey("tweetType") as! Int)
                self.resultsTable.reloadData()

            }

            self.refresher.endRefreshing()

        }
    }

}

答案 2 :(得分:0)

我无法弄清楚如何在另一个表的对象解析中记录一个列。正如您所说,我目前正在将用户名和照片分别记录为每条推文的列。推文代码如下。在解析时我应该在tweets表中为此创建一个新列吗?列的类型应该是什么?

var tweetObj = PFObject(className:" tweets")

    tweetObj["userName"] = PFUser.currentUser()!.username
    tweetObj["profileName"] = PFUser.currentUser()!.valueForKey("profileName") as! String
    tweetObj["photo"] = PFUser.currentUser()!.valueForKey("photo") as! PFFile
    tweetObj["tweet"] = theTweet

当我尝试更新上面的代码作为下面的代码时,我收到一个错误(我在parse中创建了一个名为createdBy的对象类型。)

让user = PFObject(className:" TweetAuthor")

var tweetObj = PFObject(className:" tweets")

    tweetObj["userName"] = PFUser.currentUser()!.username
    tweetObj["profileName"] = PFUser.currentUser()!.valueForKey("profileName") as! String
    tweetObj["photo"] = PFUser.currentUser()!.valueForKey("photo") as! PFFile
    tweetObj["tweet"] = theTweet
    tweetObj["createdBy"] = user