场景:后端保存数据的时候经常有重复保存的情况,假设两个同样数据的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":"手游"
}