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 相关文章推荐
PHP 采集程序中常用的函数
Dec 09 PHP
PHP生成唯一的促销/优惠/折扣码(附源码)
Dec 28 PHP
php实现上传图片生成缩略图示例
Apr 13 PHP
浅谈php扩展imagick
Jun 02 PHP
qq登录,新浪微博登录接口申请过程中遇到的问题
Jul 22 PHP
php截取html字符串及自动补全html标签的方法
Jan 15 PHP
PHP日期函数date格式化UNIX时间的方法
Mar 19 PHP
PHP微信支付实例解析
Jul 22 PHP
yii2实现 &quot;上一篇,下一篇&quot; 功能的代码实例
Feb 04 PHP
PHP 获取 ping 时间的实现方法
Sep 29 PHP
PHP ajax+jQuery 实现批量删除功能实例代码小结
Dec 06 PHP
php 实现银联商务H5支付的示例代码
Oct 12 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
php中ob(Output Buffer 输出缓冲)函数使用方法
2007/07/21 PHP
php 求质素(素数) 的实现代码
2011/04/12 PHP
php更新mysql后获取改变行数的方法
2014/12/25 PHP
php使用post数组的键值创建同名变量并赋值的方法
2015/04/03 PHP
完美利用Yii2微信后台开发的系列总结
2016/07/18 PHP
Thinkphp5.0框架使用模型Model的获取器、修改器、软删除数据操作示例
2019/10/11 PHP
js判断鼠标同时离开两个div的思路及代码
2013/05/31 Javascript
JS连接SQL数据库与ACCESS数据库的方法实例
2013/11/21 Javascript
Vue2.0如何发布项目实战
2017/07/27 Javascript
浅析前端路由简介以及vue-router实现原理
2018/06/01 Javascript
浅析Vue项目中使用keep-Alive步骤
2018/07/27 Javascript
vue2使用keep-alive缓存多层列表页的方法
2018/09/21 Javascript
用JS实现选项卡
2020/03/23 Javascript
基于JavaScript实现表格隔行换色
2020/05/08 Javascript
原生js实现贪吃蛇游戏
2020/10/26 Javascript
JS实现多功能计算器
2020/10/28 Javascript
解决elementui表格操作列自适应列宽
2020/12/28 Javascript
vue element和nuxt的使用技巧分享
2021/01/14 Vue.js
python遍历文件夹并删除特定格式文件的示例
2014/03/05 Python
Python随机生成均匀分布在单位圆内的点代码示例
2017/11/13 Python
NetworkX之Prim算法(实例讲解)
2017/12/22 Python
django中模板的html自动转意方法
2018/05/27 Python
Python unittest单元测试框架总结
2018/09/08 Python
python 实现创建文件夹和创建日志文件的方法
2019/07/07 Python
如何利用python给图片添加半透明水印
2019/09/06 Python
Pandas+Matplotlib 箱式图异常值分析示例
2019/12/09 Python
在pycharm中实现删除bookmark
2020/02/14 Python
python+gdal+遥感图像拼接(mosaic)的实例
2020/03/10 Python
让IE支持CSS3的不完全兼容方案
2014/09/19 HTML / CSS
利用HTML5中的Canvas绘制一张笑脸的教程
2015/05/07 HTML / CSS
介绍一下Cookie和Session及他们之间的区别
2012/11/20 面试题
股东合作协议书
2014/04/14 职场文书
四风自我剖析材料思想汇报
2014/10/01 职场文书
2015年乡镇纪委工作总结
2015/05/26 职场文书
单位病假条范文
2015/08/17 职场文书
源码安装apache脚本部署过程详解
2022/09/23 Servers