想把数据库里获取的字段内容随机显示出来,并且不重复。应该怎么办?用array_rand函数会有重复的。
6 回答
![?](http://img1.sycdn.imooc.com/533e4d510001c2ad02000200-100-100.jpg)
杨魅力
TA贡献1811条经验 获得超6个赞
用洗牌方法啊
shuffle($array);
发牌的时候不是从牌堆里随机取牌,而是先洗牌,洗好后按顺序发就行了
所以先用shuffle打乱顺序,然后用array_slice,确定从哪取,取几个就ok了
下面的邀请回答就是打乱顺序+分页
![?](http://img1.sycdn.imooc.com/54584d6100015f5802200220-100-100.jpg)
繁星点点滴滴
TA贡献1803条经验 获得超3个赞
贴一个我自己做过的,跟你这个有点类似的需求吧,我当时需求是每天随机96个元素显示,也是做个每日推荐的功能,你看对你有参考不。我用了个取巧的办法。
$datetime = date('Y-m-d', time());
//看看redis是否缓存了今天的数据
$lcount = $redis->strlen('wpapre:date:' . $datetime . ':' . $gid);
if ($lcount == 0) {
//取个随机数
$randNum = mt_rand(100, $redis->zCard($zsetkey) == 0 ? 200 : $redis->zCard($zsetkey));
//随机取96个元素
$tmpArr = $redis->zRevRange($zsetkey, $randNum, $randNum + 95, false);
$redis->setex('wpapre:date:' . $datetime . ':' . $gid, 60 * 60 * 25, json_encode($tmpArr));
}
$list = json_decode($redis->get('wpapre:date:' . $datetime . ':' . $gid));
//当天随机的分组显示
$data = array_slice($list, $offset, $offset + $limit - 1);
======================================
回答跟上面其实差不多,数组去重用array_unique,随机的话就是shuffle和array_rand,
最后那个从第10个开始的没看太明白什么意思,我理解成你是想分组显示,做法跟做分页一样,
使用array_slice函数。
- 6 回答
- 0 关注
- 595 浏览
添加回答
举报
0/150
提交
取消