Redis-hash类型数据实现购物车

hash类型应用场景

业务场景

电商网站购物车设计与实现


Redis-hash类型数据实现购物车_第1张图片
业务分析
  • 仅分析购物车的redis存储模型,添加、浏览、更改数量、删除、清空
  • 购物车与数据库间持久化同步(不讨论)
  • 购物车与订单间关系(不讨论)
    提交购物车:读取数据生成订单
    商家临时价格调整:隶属于订单级别
  • 未登录用户购物车信息存储(不讨论)
    cookie存储
解决方案
  • 以客户id作为key,每位客户创建一个hash存储结构存储对应的购物车信息
  • 将商品编号作为field,购买数量作为value进行存储
  • 添加商品:追加全新的field与value
  • 浏览:遍历hash
  • 更改数量:自增/自减,设置value值
  • 删除商品:删除field
  • 清空:删除key
当前设计是否加速了购物车的呈现?

当前仅仅是将数据存储到了redis中,并没有起到加速的作用,商品信息还需要二次查询数据库

  • 每条购物车中的商品记录保存成两条field
  • field1专用于保存购物数量
    命名格式:商品id:nums
    保存数据:数值
  • field2专用于保存购物车中显示的信息,包含文字描述,图片地址,所属商家信息等
    命名格式:商品id:info
    保存数据:json
hsetnx key field value

你可能感兴趣的:(Redis-hash类型数据实现购物车)