用 Redis SETNX 防止数据重复保存

场景:后端保存数据的时候经常有重复保存的情况,假设两个同样数据的POST请求被前端发送了两次,后端如果不做验证那就会被保存两次。而那种先查询数据库,如果数据库中没有这条数据再进行保存。显然是行不通的。

一、

假设向数据库MongoDB新建一个游戏。游戏存储的json如下:

{
   "name":"吃鸡战场",
   "type":"手游"
}

而name字段加type字段 可构成一个游戏唯一的标志。即:手游中不会存在另一款游戏也叫“吃鸡战场”。那么在写入数据库MongoDB之前的代码中。 我们可以存储一个md5('手游吃鸡战场‘) 值。 字符串"吃鸡战场" 的md5 值为:“38c37fcbd39949b97fb0e6ad759f5d31”。

在Redis中存储:

1.
> setnx 38c37fcbd39949b97fb0e6ad759f5d31 1

二、
①如果命令1返回1,则表明这个key 38c37fcbd39949b97fb0e6ad759f5d31,没有被设置过。但是此时并不能证明:

{
   "name":"吃鸡战场",
   "type":"手游"
}

这条没有被保存。需要查询MongoDB,如果查询数据库后确实不存在,那么继续设置38c37fcbd39949b97fb0e6ad759f5d31 的过期时间。

2.
> expire abc 5

然后将数据保存到MongoDB。

如果查询MongoDB后发现存在则直接返回给前端对应的HTTP状态码和提示。

②如果命令1返回0,则表明这个key 38c37fcbd39949b97fb0e6ad759f5d31,已经被设置过。表明这条数据已经被保存了,直接返回给前端对应的HTTP状态码和提示。

{
   "name":"吃鸡战场",
   "type":"手游"
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值