我想过滤receiverID,以便我只获得唯一的receiverID。以下是我的代码:
func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell{
let cell = collectionView.dequeueReusableCell(withReuseIdentifier: cellIdentifier, for: indexPath) as! InboxCollectionViewCell
cell.inboxMessage.text = chats[indexPath.row].receiverID
return cell
}
func loadPosts() {
let senderIDNumber = Auth.auth().currentUser?.uid
let chatsRef = db.collection("chats")
chatsRef.whereField("senderID", isEqualTo: senderIDNumber!)
.addSnapshotListener { querySnapshot, error in
guard let documents = querySnapshot?.documents else {
print("Error fetching documents: \(error!)")
return
}
for document in documents {
let messageText = document.data()["message"] as? String
let senderIDNumber = document.data()["senderID"] as? String
let receiverIDNumber = document.data()["receiverID"] as? String
let timestamp = document.data()["timestamp"] as? String
let conversationsCounter = document.data()["conversationsCounter"] as? Int
let chat = Chat(messageTextString: messageText!, senderIDNumber: senderIDNumber!, receiverIDNumber: receiverIDNumber!, timeStampString: timestamp!, conversationsCounterInt: conversationsCounter!)
self.chats.append(chat)
print(self.chats)
self.collectionView.reloadData()
}
}
}
有关如何过滤以使我的inboxMessage显示唯一用户的任何想法?我正在使用Firebase / Firestore作为我的数据库。
答案 0 :(得分:0)
听起来您正在尝试按收件人对结果进行分组。 Firestore的查询API中没有这样的group by子句。您必须自己遍历所有消息,并将它们分组到客户端。
chatsRef.whereField("senderID", isEqualTo: senderIDNumber!)
.order(by: "receiverID")
.addSnapshotListener { querySnapshot, error in
...
let lastReceiverID = "";
for document in documents {
...
let receiverIDNumber = document.data()["receiverID"] as? String
if receiverIDNumber != lastReceiverId {
// TODO: do something with receiverIDNumber
}
lastReceiverId = receiverIDNumber
}
事实上,您的数据模型目前看起来像是在所有用户之间有一个很长的聊天消息列表,这感觉就像从聊天的关系数据模型中直接翻译。
在NoSQL数据库中,您通常希望将数据建模得更接近应用程序的实际需求。例如,您似乎正在尝试显示给定发件人的所有邮件。在这种情况下,请考虑将这些消息存储在单独的集合中。例如。如果您已经拥有顶级/users
集合,则可以在sent
下的/users/$uid/sent
子集合中发送消息:import pdb; pdb.set_trace()
。
有关数据建模注意事项的更多信息,请参阅NoSQL data modeling和Todd在Cloud Firestore上的视频系列(episode 1和episode 2)。