Rumah > pembangunan bahagian belakang > tutorial php > 关于feed存储于redis(hash或list)中的一些疑问。

关于feed存储于redis(hash或list)中的一些疑问。

WBOY
Lepaskan: 2016-06-06 20:47:04
asal
1375 orang telah melayarinya

写在最先,可能提问得不是很好,至少意思应该表达清楚了,望各位指导。

因为业务需求,需要将feed数据表全部倒入redis中,做数据存储功能,于此带来了一系列的疑问和不解。

feed表中有以下数据:

<code>$data = array(
        array("feed_id"=>1,"uid"=>1,"content"=>"xiaoxijilu"),
        array("feed_id"=>2,"uid"=>2,"content"=>"xiaoxijilu"),
        /*****以此类推还有很多****/
        );
</code>
Salin selepas log masuk
Salin selepas log masuk

若将feed在redis中做hash存储,如:hset feed:list feed_id data;
存储的时候代码为:

<code>foreach($data as $k => $v){
   $redis->hset("feed:lists",$v["feed_id"],$v);
}

//x先别管hset 和 hmset的区别
</code>
Salin selepas log masuk
Salin selepas log masuk
<code>此时的redis KEY为:feed:list 的HASH表中已存在很多数据,若需要筛选出我的动态也就是$uid = 1 的动态,如何做?
按照我的理解,如果真的需要做 $uid = 1 的动态这需要另外创建一个KEY为feed:$uid:list的HASH表?

如果真的按照我所想的进行操作,是否会造成数据冗余?
</code>
Salin selepas log masuk
Salin selepas log masuk

姑且第一条我们已经解决,那又会重复第一条的疑问, 若用户A($uid = 1),且有,B($uid = 2),C($uid = 3),D($uid = 4) 的好有(姑且目前考虑所有用户均和A已是相互的好友关系),此时的A POST一条新feed(feed_id = 100),那feed:list肯定需要add feed_id100的动态,此时B , C , D 如何收到A PUSH的动态?

<code>我能想到的办法,就是按照第一条去解决,`B , C ,D` 分别有自己的`feed.list` 为 `feed:2:list` , `feed:3:list` , `feed:4:list`, A POST的同时主动PUSH  feed 到对方的list中。

那如果按照我的设想去解决,假设A 有 1W 或者更多的 好有,此时的主动PUSH性能如何解决? 

于此同时,如何解决 单方关注(单方好友)的情况?

同样,删除feed,如何解决? 


希望大神能提点!!!! 

感谢 
</code>
Salin selepas log masuk
Salin selepas log masuk

这个问题已被关闭,原因:

回复内容:

写在最先,可能提问得不是很好,至少意思应该表达清楚了,望各位指导。

因为业务需求,需要将feed数据表全部倒入redis中,做数据存储功能,于此带来了一系列的疑问和不解。

feed表中有以下数据:

<code>$data = array(
        array("feed_id"=>1,"uid"=>1,"content"=>"xiaoxijilu"),
        array("feed_id"=>2,"uid"=>2,"content"=>"xiaoxijilu"),
        /*****以此类推还有很多****/
        );
</code>
Salin selepas log masuk
Salin selepas log masuk

若将feed在redis中做hash存储,如:hset feed:list feed_id data;
存储的时候代码为:

<code>foreach($data as $k => $v){
   $redis->hset("feed:lists",$v["feed_id"],$v);
}

//x先别管hset 和 hmset的区别
</code>
Salin selepas log masuk
Salin selepas log masuk
<code>此时的redis KEY为:feed:list 的HASH表中已存在很多数据,若需要筛选出我的动态也就是$uid = 1 的动态,如何做?
按照我的理解,如果真的需要做 $uid = 1 的动态这需要另外创建一个KEY为feed:$uid:list的HASH表?

如果真的按照我所想的进行操作,是否会造成数据冗余?
</code>
Salin selepas log masuk
Salin selepas log masuk

姑且第一条我们已经解决,那又会重复第一条的疑问, 若用户A($uid = 1),且有,B($uid = 2),C($uid = 3),D($uid = 4) 的好有(姑且目前考虑所有用户均和A已是相互的好友关系),此时的A POST一条新feed(feed_id = 100),那feed:list肯定需要add feed_id100的动态,此时B , C , D 如何收到A PUSH的动态?

<code>我能想到的办法,就是按照第一条去解决,`B , C ,D` 分别有自己的`feed.list` 为 `feed:2:list` , `feed:3:list` , `feed:4:list`, A POST的同时主动PUSH  feed 到对方的list中。

那如果按照我的设想去解决,假设A 有 1W 或者更多的 好有,此时的主动PUSH性能如何解决? 

于此同时,如何解决 单方关注(单方好友)的情况?

同样,删除feed,如何解决? 


希望大神能提点!!!! 

感谢 
</code>
Salin selepas log masuk
Salin selepas log masuk
Label berkaitan:
sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan