想把数据库里获取的字段内容随机显示出来,并且不重复。
应该怎么办?
用array_rand函数会有重复的。
用洗牌方法啊
shuffle($array);
发牌的时候不是从牌堆里随机取牌,而是先洗牌,洗好后按顺序发就行了
所以先用shuffle打乱顺序,然后用array_slice,确定从哪取,取几个就ok了
下面的邀请回答就是打乱顺序+分页
获取随机元素的话建议用shuffle代替array_rand
shuffle可以随机打乱一个数组
具体用法
$user = array(
0 => array(
'id' => 1,
'name' => '张三',
'email' => 'zhangsan@sina.com',
),
1 => array(
'id' => 2,
'name' => '李四',
'email' => 'lisi@163.com',
),
2 => array(
'id' => 5,
'name' => '王五',
'email' => '10000@qq.com',
)
);
shuffle($user);
var_dump($user);
输出
array(3) {
[0]=>
array(3) {
["id"]=>
int(1)
["name"]=>
string(6) "张三"
["email"]=>
string(17) "zhangsan@sina.com"
}
[1]=>
array(3) {
["id"]=>
int(5)
["name"]=>
string(6) "王五"
["email"]=>
string(12) "10000@qq.com"
}
[2]=>
array(3) {
["id"]=>
int(2)
["name"]=>
string(6) "李四"
["email"]=>
string(12) "lisi@163.com"
}
}
详见:
自己写个方法吧
function get_rand_keys($list, $n) {
$keys = array();
for ($i = 0; $i < $n; $i++) {
$rand_key = array_rand($list, 1);
array_push($keys, $rand_key);
unset($list[$rand_key]);
}
return $keys;
}
$rand_key = get_rand_keys($tags,9);
foreach ($rand_key as $val) {
$info[] = $tags[$val][0]["name"];
}
贴一个我自己做过的,跟你这个有点类似的需求吧,我当时需求是每天随机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函数。
1 回答4.2k 阅读✓ 已解决
3 回答1.9k 阅读✓ 已解决
2 回答2.3k 阅读✓ 已解决
2 回答853 阅读✓ 已解决
1 回答1.4k 阅读✓ 已解决
2 回答2.3k 阅读
1 回答717 阅读✓ 已解决
如果是数据库是mysql的话,可以加
distinct
语句避免查询重复。再者可以通过php去重,php也有相关函数如:array_unique()
。再不行可以自己写个递归,或者循环,新建一个数组,利用in_array()
判断从数据库查出来的数据是否在新建的数组里。再不济可以丢到redis的有序集合里。