写在最先,可能提问得不是很好,至少意思应该表达清楚了,望各位指导。
因为业务需求,需要将feed数据表全部倒入redis中,做数据存储功能,于此带来了一系列的疑问和不解。
feed表中有以下数据:
$data = array( array(feed_id=>1,uid=>1,content=>xiaoxijilu), array(feed_id=>2,uid=>2,content=>xiaoxijilu), /*****以此类推还有很多****/ );
若将feed在redis中做hash存储,如:hset feed:list feed_id data;
存储的时候代码为:
foreach($data as $k => $v){ $redis->hset(feed:lists,$v[feed_id],$v);}//x先别管hset 和 hmset的区别
此时的redis key为:feed:list 的hash表中已存在很多数据,若需要筛选出我的动态也就是$uid = 1 的动态,如何做?按照我的理解,如果真的需要做 $uid = 1 的动态这需要另外创建一个key为feed:$uid:list的hash表?如果真的按照我所想的进行操作,是否会造成数据冗余?
姑且第一条我们已经解决,那又会重复第一条的疑问, 若用户a($uid = 1),且有,b($uid = 2),c($uid = 3),d($uid = 4) 的好有(姑且目前考虑所有用户均和a已是相互的好友关系),此时的a post一条新feed(feed_id = 100),那feed:list肯定需要add feed_id为100的动态,此时b , c , d 如何收到a push的动态?
我能想到的办法,就是按照第一条去解决,`b , c ,d` 分别有自己的`feed.list` 为 `feed:2:list` , `feed:3:list` , `feed:4:list`, a post的同时主动push feed 到对方的list中。那如果按照我的设想去解决,假设a 有 1w 或者更多的 好有,此时的主动push性能如何解决? 于此同时,如何解决 单方关注(单方好友)的情况?同样,删除feed,如何解决? 希望大神能提点!!!! 感谢
这个问题已被关闭,原因:
回复内容: 写在最先,可能提问得不是很好,至少意思应该表达清楚了,望各位指导。
因为业务需求,需要将feed数据表全部倒入redis中,做数据存储功能,于此带来了一系列的疑问和不解。
feed表中有以下数据:
$data = array( array(feed_id=>1,uid=>1,content=>xiaoxijilu), array(feed_id=>2,uid=>2,content=>xiaoxijilu), /*****以此类推还有很多****/ );
若将feed在redis中做hash存储,如:hset feed:list feed_id data;
存储的时候代码为:
foreach($data as $k => $v){ $redis->hset(feed:lists,$v[feed_id],$v);}//x先别管hset 和 hmset的区别
此时的redis key为:feed:list 的hash表中已存在很多数据,若需要筛选出我的动态也就是$uid = 1 的动态,如何做?按照我的理解,如果真的需要做 $uid = 1 的动态这需要另外创建一个key为feed:$uid:list的hash表?如果真的按照我所想的进行操作,是否会造成数据冗余?
姑且第一条我们已经解决,那又会重复第一条的疑问, 若用户a($uid = 1),且有,b($uid = 2),c($uid = 3),d($uid = 4) 的好有(姑且目前考虑所有用户均和a已是相互的好友关系),此时的a post一条新feed(feed_id = 100),那feed:list肯定需要add feed_id为100的动态,此时b , c , d 如何收到a push的动态?
我能想到的办法,就是按照第一条去解决,`b , c ,d` 分别有自己的`feed.list` 为 `feed:2:list` , `feed:3:list` , `feed:4:list`, a post的同时主动push feed 到对方的list中。那如果按照我的设想去解决,假设a 有 1w 或者更多的 好有,此时的主动push性能如何解决? 于此同时,如何解决 单方关注(单方好友)的情况?同样,删除feed,如何解决? 希望大神能提点!!!! 感谢