巴扎黑2017-04-22 09:01:31
如果新闻有ID或者唯一标识符的话。可以考虑用redis的集合类型。而且集合的唯一性,防止了重复添加问题!
redis.sadd('personmark:userID',newsID);//向用户集合添加一个元素
redis.smembers('personmark:userID');//一次性获取用户所有收集的新闻ID
巴扎黑2017-04-22 09:01:31
使用排序集合zset;
key为用户ID;
member为新闻唯一性ID;
score为以之前某一天开始的日期增量(比如,从2015-1-1日开始算,今天的score就是155?);有了score之后就取出来就不用再排序,直接显示;
zadd(key, score, member):添加新闻
zrank(key, member):按score从小到大返回,也就是收藏的新闻按日期从新往旧排序;
zrangebyscore(key, min, max):返回score从start到end的集合,用来实现新闻的翻页显示;
大家讲道理2017-04-22 09:01:31
key: news_fav_uid
value: 新闻ID的集合(数组)
其中uid是用户ID.
$news_ids = array(1024,1025,1026);
echo json_encode($news_ids);
无论你用的是Memcached/Redis/MySQL都可以这样存储.
array_push把新的收藏压到$news_ids数组的末尾.
你要按时间排序,只需要json_decode解码后array_reverse翻转数组后foreach输出.