0

我知道在 SQL 中将 2 个不同的对象相互关联,其中一个将使用 1 个表中的主键和另一个表中的外键。由于 FirebaseDatabase 使用 JSON/NoSQL 这是不可能的。如果我有 2 个对象是 UserPostEntity 和 PostEntity,一旦用户发表了帖子/评论,我将如何将 UserPostEntity 与 PostEntity 关联,以及如何使用用户发表的帖子/评论自动更新 PostEntity?

用户实体对象:

import Foundation

    class UserEntity{

        var userID: String
        var postedComment: String
        var postDate: String
        var postID: PostEntity

        init(userID: String, postedComment: String, postDate: String, postID: PostEntity){
            self.userID = userID
            self.postedComment = postedComment
            self.postDate = postDate
            self.postID = postID
        }
    }

PostEntity 对象:

import Foundation

class PostEntity{

    var userID: String
    var postID: String
    var postedComment: String
    var postDate: String

    init(userID: String, postID: String, postedComment: String, postDate: String){
        self.userID = userID
        self.postID = postID
        self.postedComment = postedComment
        self.postDate = postDate
    }
}
4

1 回答 1

2

如果您可以在 Firebase 中构建数据,那就更好了。以下链接提供了有关在 Firebase 中结构化数据的良好直觉:

https://firebase.googleblog.com/2013/04/denormalizing-your-data-is-normal.html https://www.firebase.com/docs/web/guide/structuring-data.html

您可以定义您的user表格,posts如下所示:

user{
    "u1" {
    
         userName : "abc",
         posts {
              p1 : true,
              p2 : true
          }
        },
        
        "u2" {
    
         userName : "def",
         posts {
              p3 : true,
              p4 : true
          }
        }
        
  }
  
  post{
        "p1"{
            userId : "u1",
            postComment : "hello ios",
            postDate : "1467570919"
            },
        "p2"{
            userId : "u1",
            postComment : "ios",
            postDate : "1467570920"
            },
        "p3"{
            userId : "u2",
            postComment : "hello ios",
            postDate : "1467570921"
            },
        "p4"{
            userId : "u2",
            postComment : "hello ios",
            postDate : "1467570922"
            }
    }

您也可以按如下方式创建实体:

class UserEntity{

        var userID: String
        var userName : String
        var posts: Dictionary<String, Bool>?
        var ref : FIRDatabaseReference?

        init(userID: String, userName: String, posts: Dictionary<String, Bool>?){
            self.userID = userID
            self.userName = userName
            self.posts = posts
            self.ref = nil
        }
    }
    
    
    class PostEntity{

    var pId: String
    var uId: String
    var postedComment: String
    var postDate: NSTimeInterval
    var ref : FIRDatabaseReference?

    init(pId: String, uId: String, postedComment: String, postDate: NSTimeInterval){
        self.pId= pId
        self.uId = uId
        self.postedComment = postedComment
        self.postDate = postDate
        self.ref = nil
    }
}

此外,您还希望按照本文中UserEntity回答构建您的和PostEntity实体。

当用户添加新帖子时,您必须更新table的posts属性。userp5 :truep5u1

于 2016-07-16T18:17:05.587 回答