php中通过数组进行高效随机抽取指定条记录的算法


Posted in PHP onSeptember 09, 2013

php使用数组array_rand()函数进行高效随机抽取指定条数的记录,可以随机抽取数据库中的记录,适合进行随机展示和抽奖程序。

该算法主要是利用php的array_rand()函数,下面看一下array_rand()函数的主要功能:

array_rand—从数组中随机取出一个或多个单元

mixed array_rand(array $input[,int $num_req] )

array_rand()在你想从数组中取出一个或多个随机的单元时相当有用。它接受input作为输入数组和一个可选的参数num_req,指明了你想取出多少个单元 - 如果没有指定,默认为 1。

如果你只取出一个,array_rand()返回一个随机单元的键名,否则就返回一个包含随机键名的数组。这样你就可以随机从数组中取出键名和值。

下面我们看一下小例子:

<?php
srand((float) microtime() * 10000000);
$input = array("Neo", "Morpheus", "Trinity", "Cypher", "Tank");
$rand_keys = array_rand($input, 2);
print $input[$rand_keys[0]] . "\n";
print $input[$rand_keys[1]] . "\n";
?>

该函数会随机抽取$list数组中的记录号,需要记录内容只需要输出即可。

下面看一段数据库随机抽取特定条记录的例子:

<?php
$list = $DB->where("status=1 and flag=1")->order('sort')->select();
unset($Case);
$count = count($list);
$rand_list=range(0, $count-1);
$rand_list = array_rand($rand_list, 10);
$tuijian_array = array();
foreach ($rand_list as $key) {
    $tuijian_array[] = $list[$key];
}
unset($case_list);
print_r($tuijian_array);
?>
PHP 相关文章推荐
检查url链接是否已经有参数的php代码 添加 ? 或 &amp;
Feb 09 PHP
PHP项目开发中最常用的自定义函数整理
Dec 02 PHP
探讨:如何编写PHP扩展
Jun 13 PHP
慎用preg_replace危险的/e修饰符(一句话后门常用)
Jun 19 PHP
php使用curl存储cookie的示例
Mar 31 PHP
免费的ip数据库淘宝IP地址库简介和PHP调用实例
Apr 08 PHP
PHP反向代理类代码
Aug 15 PHP
destoon调用企业会员公司形象图片的实现方法
Aug 21 PHP
php实现将任意进制数转换成10进制的方法
Apr 17 PHP
php通过exif_read_data函数获取图片的exif信息
May 21 PHP
php实现图片上传并利用ImageMagick生成缩略图
Mar 14 PHP
jQuery+PHP实现图片上传并提交功能
Jul 27 PHP
php文件夹与文件目录操作函数介绍
Sep 09 #PHP
php读取本地文件常用函数(fopen与file_get_contents)
Sep 09 #PHP
PHP函数之日期时间函数date()使用详解
Sep 09 #PHP
PHP json_encode中文乱码问题的解决办法
Sep 09 #PHP
分享PHP header函数使用教程
Sep 05 #PHP
php增删改查示例自己写的demo
Sep 04 #PHP
php使用异或实现的加密解密实例
Sep 04 #PHP
You might like
咖啡冲泡指南 咖啡有哪些制作方式 单品咖啡 意式咖啡
2021/03/06 冲泡冲煮
10个可以简化php开发过程的MySQL工具
2010/04/11 PHP
php下通过curl抓取yahoo boss 搜索结果的实现代码
2011/06/10 PHP
解决php使用异步调用获取数据时出现(错误c00ce56e导致此项操作无法完成)
2013/07/03 PHP
php 邮件发送问题解决
2014/03/22 PHP
详解PHP中的mb_detect_encoding函数使用方法
2015/08/18 PHP
PHP 观察者模式深入理解与应用分析
2019/09/25 PHP
怎么清空javascript数组
2013/05/11 Javascript
JS关闭窗口或JS关闭页面的几种代码分享
2013/10/25 Javascript
jquery表单验证插件(jquery.validate.js)的3种使用方式
2015/03/28 Javascript
javascript表格隔行变色加鼠标移入移出及点击效果的方法
2015/04/10 Javascript
jQuery切换所有复选框选中状态的方法
2015/07/02 Javascript
浅析jQuery Ajax请求参数和返回数据的处理
2016/02/24 Javascript
让编辑器支持word复制黏贴、截屏的js代码
2016/10/17 Javascript
js实现选项卡内容切换以及折叠和展开效果【推荐】
2017/01/08 Javascript
jquery实现焦点轮播效果
2017/02/23 Javascript
JavaScript this使用方法图解
2020/02/04 Javascript
微信小程序实现简单文字跑马灯
2020/05/26 Javascript
layui实现显示数据表格、搜索和修改功能示例
2020/06/03 Javascript
js实现简易ATM功能
2020/10/27 Javascript
Python测试模块doctest使用解析
2019/08/10 Python
python paramiko远程服务器终端操作过程解析
2019/12/14 Python
python3实现从kafka获取数据,并解析为json格式,写入到mysql中
2019/12/23 Python
python读取多层嵌套文件夹中的文件实例
2020/02/27 Python
构建高效的python requests长连接池详解
2020/05/02 Python
css3 自定义字体font-face使用介绍
2014/05/14 HTML / CSS
澳大利亚婴儿喂养品牌:Cherub Baby
2018/11/01 全球购物
如何用PHP实现邮件发送
2012/12/26 面试题
Shell如何接收变量输入
2016/08/06 面试题
股份合作协议书
2014/04/12 职场文书
初中学校军训方案
2014/05/09 职场文书
医生爱岗敬业演讲稿
2014/08/26 职场文书
习近平在党的群众路线教育实践活动总结大会上的讲话
2014/10/21 职场文书
打架赔偿协议书范本
2014/10/26 职场文书
老乡聚会通知
2015/04/23 职场文书
护士心得体会范文
2016/01/25 职场文书