redis缓存如何做到与数据库数据一致阿?

假设数据库有一个user表,存入redis的键为users,值为Map<id,user>。

如果不设置键的过期时间还可以做到。但是设置了键的过期时间后,当这个键过期了,
从新把数据读到Map<id,user>中,如果这时候只读了一个user,比如{id=1,name=张三,mark=90},
因为数据还没读取完,我们还没把这个map放入redis。
恰好这时有人修改了张三的数据,把mark修改成90,修改的代码逻辑是先把数据库的张三mark修改为90,然后去
redis修改users对应的map的张三的数据,但是redis中现在还没有users这个键。
所以最后造成的结果是--->数据库中:张三的mark为90 。 redis中:张三的mark为100。
这种不一致的情况该怎么解决呢?

撒科打诨
浏览 667回答 1
1回答

MMMHUHU

你往极限处想,只要是在两个地方的数据,就没有办法保证时时相同,光也是有速度的。不要想着用缓存的优点(优点是啥?)又没有缓存的缺点?(缺点是在系统中可以忽略或者无所谓或者可以忍受的)。缓存是用来保存不常变动的数据,用以减轻数据库负担,如果你一直检查,一直更新的话,数据库负担一点都没有减轻,甚至更高了,你还要缓存作甚?
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

SQL Server
Java