ZBLOG

ID怎么不见了

在之前的 Redis 数据结构设计中,我们可以将 _id 字段也包括在内,以确保每个订阅的唯一性。我们可以将其存储为一个哈希表中的一个字段,或者作为 Redis 键的一部分。

修改后的数据结构设计

更新我们的 Hash 结构以包含 _id 字段:

  • Redis Key: subscription:<subscriptionId>
  • Hash Fields:
    • _id
    • nfStatusNotificationUri

示例代码实现(包含 ID)

以下是修改后的代码示例,其中包含了 _id 字段的存储:

  1. package main
  2. import (
  3. "context"
  4. "fmt"
  5. "log"
  6. "github.com/go-redis/redis/v8"
  7. )
  8. type Subscription struct {
  9. ID string `json:"_id"`
  10. NfStatusNotificationUri string `json:"nfStatusNotificationUri"`
  11. SubscriptionId string `json:"subscriptionId"`
  12. }
  13. // 将订阅数据保存到Redis
  14. func storeSubscription(ctx context.Context, rdb *redis.Client, subscription Subscription) error {
  15. key := fmt.Sprintf("subscription:%s", subscription.SubscriptionId)
  16. // 存入Hash表,包括_id
  17. err := rdb.HSet(ctx, key, map[string]interface{}{
  18. "_id": subscription.ID,
  19. "nfStatusNotificationUri": subscription.NfStatusNotificationUri,
  20. }).Err()
  21. return err
  22. }
  23. func main() {
  24. ctx := context.Background()
  25. rdb := redis.NewClient(&redis.Options{
  26. Addr: "localhost:6379",
  27. })
  28. defer rdb.Close()
  29. subscriptions := []Subscription{
  30. {ID: "678768d1b3a57bc85615da79", NfStatusNotificationUri: "", SubscriptionId: "78"},
  31. {ID: "678768d8b3a57bc85615da7a", NfStatusNotificationUri: "", SubscriptionId: "39"},
  32. }
  33. for _, sub := range subscriptions {
  34. err := storeSubscription(ctx, rdb, sub)
  35. if err != nil {
  36. log.Fatalf("Failed to store subscription %s in Redis : %v", sub.SubscriptionId, err)
  37. }
  38. }
  39. fmt.Println("Subscriptions stored successfully!")
  40. }

总结

现在,每个哈希表中都包括了 _id 字段,允许你在需要时轻松访问该唯一标识符。这有助于保持数据的一致性和完整性,同时也使得从 Redis 中获取信息更加方便。


内容由零声教学AI助手提供,问题来源于学员提问

本站部分文章来源于网络,版权归原作者所有,如有侵权请联系站长删除。
转载请注明出处:https://golang.0voice.com/?id=21134

分享:
扫描分享到社交APP
上一篇
下一篇
发表列表
游客 游客
此处应有掌声~
评论列表

还没有评论,快来说点什么吧~

联系我们

在线咨询: 点击这里给我发消息

微信号:3007537140

上班时间: 10:30-22:30

关注我们
x

注册

已经有帐号?