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实现文件上传二法
Oct 09 PHP
PHP+SQL 注入攻击的技术实现以及预防办法
Dec 29 PHP
php设计模式 Decorator(装饰模式)
Jun 26 PHP
php自动识别文件编码并转换为UTF-8的方法
Jun 12 PHP
php堆排序实现原理与应用方法
Jan 03 PHP
php获取客户端电脑屏幕参数的方法
Jan 09 PHP
php实现修改新闻时删除图片的方法
May 12 PHP
PHP内核探索之解释器的执行过程
Dec 22 PHP
PHP PDOStatement::columnCount讲解
Jan 30 PHP
PHP实现关键字搜索后描红功能示例
Jul 03 PHP
PHP实现简易用户登录系统
Jul 10 PHP
浅析PHP中json_encode与json_decode的区别
Jul 15 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
模仿OSO的论坛(五)
2006/10/09 PHP
php使用pdo连接mssql server数据库实例
2014/12/25 PHP
深入理解PHP类的自动载入机制
2016/09/16 PHP
php使用Swoole实现毫秒级定时任务的方法
2020/09/04 PHP
让您的菜单不离网站
2006/10/03 Javascript
一个用js实现的页内搜索代码
2007/05/23 Javascript
JQuery 插件模板 制作jquery插件的朋友可以参考下
2010/03/17 Javascript
javscript对象原型的一些看法
2010/09/19 Javascript
jQuery中RadioButtonList的功能及用法实例介绍
2013/08/23 Javascript
在子窗口中关闭父窗口的一句代码
2013/10/21 Javascript
异步JS框架的作用以及实现方法
2015/10/29 Javascript
JavaScript比较当前时间是否在指定时间段内的方法
2016/08/02 Javascript
jQuery EasyUI中的日期控件DateBox修改方法
2016/11/09 Javascript
JS表单验证方法实例小结【电话、身份证号、Email、中文、特殊字符、身份证号等】
2017/02/14 Javascript
轻松理解JavaScript闭包
2017/03/14 Javascript
Vue.js 实现数据展示全部和收起功能
2018/09/05 Javascript
微信小程序用户拒绝授权的处理方法详解
2019/09/20 Javascript
如何使用JavaScript检测空闲的浏览器选项卡
2020/05/28 Javascript
python求众数问题实例
2014/09/26 Python
python增加矩阵维度的实例讲解
2018/04/04 Python
Python基于递归实现电话号码映射功能示例
2018/04/13 Python
对python程序内存泄漏调试的记录
2018/06/11 Python
使用python进行拆分大文件的方法
2018/12/10 Python
Python实现时间序列可视化的方法
2019/08/06 Python
python爬取Ajax动态加载网页过程解析
2019/09/05 Python
简单介绍HTML5中的文件导入
2015/05/08 HTML / CSS
Book Depository澳大利亚:世界领先的专业在线书店之一
2018/12/27 全球购物
英国健身超市:Fitness Superstore
2019/06/17 全球购物
初二政治教学反思
2014/01/12 职场文书
酒店员工职业生涯规划
2014/02/25 职场文书
学校机关党总支领导班子整改工作方案
2014/10/26 职场文书
党支部创先争优公开承诺书
2015/04/30 职场文书
因家庭原因离职的辞职信范文
2015/05/12 职场文书
家访教师心得体会
2016/01/23 职场文书
2019企业文化管理制度范本!
2019/08/06 职场文书
mysql 直接拷贝data 目录下文件还原数据的实现
2021/07/25 MySQL