今天我们要实现从随机抽取一条数据库记录的功能,并且抽取出来的数据记录不能重复;

  1、首先我们看文章表中的数据:

  

  2、实现功能代码如下:

  

  1   /**
* 获取随机的N篇文篇
* @param int $len 文章篇数
*/
public static function getRandom($len = 6) {
# 查询数据库,得到最小Id
# SELECT min(id) FROM mimi_aritcle
$min = Db::name(self::$tb)->field('min(id)')->select();
$min = $min[0]['min(id)']; # 查询数据库,得到最大id
# SELECT max(id) FROM mimi_article
$max = Db::name(self::$tb)->field('max(id)')->select();
$max = $max[0]['max(id)']; # 初始化存储数据
$result = [];
# 初始化id数组
$randId_arr = []; for ($i = 1; $i <= $len; $i++) {
# 先设重复提取记录为false,进入do循环
$is_repeat_2 = false; # do..while,即使条件不成立,循环起码执行一次
do {
do {
# 产生一个随机整数
# 注意:产生的整数与数据库无关,不要因为两个参数是从数据库中得到的,
# 就误以为是在产生数据库中的随机id
$randId = rand($min, $max); # 判断是否有重复提取的记录
$is_repeat = in_array($randId, $randId_arr);
} while ($is_repeat); if($is_repeat_2){
# 将提取出的不同id进行入栈
array_push($randId_arr, $row[0]['id']);
} # 抽取一条数据库记录
/**
* 首先,我们要记住:
* 步骤一表图中查询数据库,获取到最小id是1, 最大id是50,就能知道数据库中一定有id=1和id=50的记录
* 所以,
* 1、这里使用id>$randId而不是id=$randId,是防止数据库中的某条记录被删除,导致找不到数据库中对应的id记录;
* 例子:
* (1) 如果随机抽取的$randId为6,那么使用条件id>$randId-1的话,就会读取到数据库中所有id>5的记录;
* 从数据库截图中,我们可以看到,能够读取到数据库id=10、20、30、40、50的记录
* (2) 如果我们使用id=$randId,随机抽取的$randId为6,那么使用功能id=$randId的话,就会读取到数据库中id=6的固定记录,
* 但是数据库中没有id=6的记录,就会发生错误
*
* 2、这里使用id>$randId-1而不是id>$randId,是为了防止我们随机抽取的数为最大数50的时候,条件不成立,
* 从而导致报错,因为id=50是数据库中最大数了
* 例如:
* (1) 如果随机抽取的$randId为最大数50,那么使用条件id>$randId-1的话,就会读取到数据库中所有id>49的记录,
* 由于符合id>49条件的只有id=50的记录,那么就能保证,我有数据可以提取到;
* (2) 如果随机抽取的$randId为最大数50,那么使用条件id>$randId的话,就会读取到数据库中所有id>50的记录,
* 但是数据库中没有符合条件的数据,就会发生错误
* (3) 如果随机抽取的$randId为最小数1,使用条件 id>$randId 的话,id = 1 的记录永远也不能被随机选中
*
* 3、这里使用order('id ASC')而不是order('id DESC')原因:当我们获取到数据后,要获取最接近$randId的值
* (1) 如果随机抽取的$randId为6,我们就能从所有id>5的记录,即id=10、20、30、40、50
* 的记录,这时候的结果是循环6次后的总体列表,那我们需要最靠近6的记录,就需要使用order('id ASC')
* 进行升序排列,这时候,列表中的第一个数据就是id=10的,就是我们想要的记录
* (2) 如果随机抽取的$randId为6,我们就能从所有id>5的记录,即id=10、20、30、40、50
* 的记录,如果使用order('id DESC'),那么我们得到的数据永远是最不靠近6的记录,即id=50的记录
* (3) 不使用order,有时候会排列不一样,(通常在数据记录不同时才会发现到)
*
* 4、这里使用limit原因:因为我们需要的是一条记录,而不是一个列表,所以,我们只需要提取符合条件的第一条记录即可
* 例子:
* (1) 如果随机抽取的$randId为6,那么使用条件id>$randId-1的话,就会读取到数据库中所有id>5的记录而不是固定一条记录;
* 从数据库截图中,我们可以看到,能够读取到数据库id=10、20、30、40、50的记录,但是我们循环一次只需要一条记录,那么
* 只需要提取第一条符合的记录,就是id=10的记录
* (2) 如果我们不使用limit的话,那么系统就会把所有符合条件的记录都提取出来
*
*/
$row = Db::name(self::$tb)
->field('id, title, href')
->where(['id' => ['>', $randId - 1]])
->order('id ASC')
->limit(0, 1)
->select(); # 判断是否有重复提取的数据库记录
$is_repeat_2 = in_array($row[0]['id'], $randId_arr);
} while ($is_repeat_2); # 将提取出来的数据库id进行入栈
array_push($randId_arr, $row[0]['id']); if(empty($row)){
return false;
} # 将提取出的所有最终数据库数据入栈
array_push($result, $row[0]);
} return $result;
}

  

  

  以上

  加油ヾ(◍°∇°◍)ノ゙

MYSQL:随机抽取一条数据库记录的更多相关文章

  1. TODO:从数据库中随机抽取一条记录

    TODO:从数据库中随机抽取一条记录 1.最直接,最粗暴的方法先计算记录的总数,然后选择一个从0到记录总数之间的随机数n,利用skip跳过n条记录,这是效率低下的的方法,首先的记录总数,在用skip会 ...

  2. laravel如何从mysql数据库中随机抽取n条数据

    laravel如何从mysql数据库中随机抽取n条数据 一.总结 一句话总结: inRandomOrder():$userQuestions=UserQuestion::where($map)-> ...

  3. php 数组 高效随机抽取指定条记录的算法

    php使用数组array_rand()函数进行高效随机抽取指定条数的记录,可以随机抽取数据库中的记录,适合进行随机展示和抽奖程序. 该算法主要是利用php的array_rand()函数,下面看一下ar ...

  4. Oracle整合Mybatis实现list数据插入时,存在就更新,不存在就插入以及随机抽取一条记录

    作者:故事我忘了¢个人微信公众号:程序猿的月光宝盒 目录 Oracle整合Mybatis实现list数据插入时,存在就更新,不存在就插入 entity 对应表中字段,如不对应,在xml中起别名 map ...

  5. MYSQL随机抽取查询 MySQL Order By Rand()效率问题

    MYSQL随机抽取查询:MySQL Order By Rand()效率问题一直是开发人员的常见问题,俺们不是DBA,没有那么牛B,所只能慢慢研究咯,最近由于项目问题,需要大概研究了一下MYSQL的随机 ...

  6. 从数据表中随机抽取n条数据有哪几种方法(join实现可以先查数据然后再拼接)

    从数据表中随机抽取n条数据有哪几种方法(join实现可以先查数据然后再拼接) 一.总结 一句话总结:最好的是这个:"SELECT * FROM table WHERE id >= (( ...

  7. sql 随机抽取几条数据的方法 推荐

    传说用这个语句管用:select top 5 * from tablename order by newid() 我放到sql的查询分析器里去执行果然管用,随机抽取5条信息,不停的换,结果我应用到程序 ...

  8. mysql 随机选取一条记录

    要从tablename表中随机提取一条记录,大家一般的写法就是:SELECT * FROM tablename ORDER BY RAND() LIMIT 1. 1 2 3 4 5 6 7 8 9 1 ...

  9. mysql随机获取一条或者多条数据

    原文地址:http://www.im286.com/thread-7091552-1-1.html 转来备份 研究一些随机的因素,主要是讲究效率问题. 语句一: MYSQL手册里面针对RAND()的提 ...

随机推荐

  1. php返回数据格式

    PHP返回HTML代码:     header('Content-type:text/html; charset=utf-8'); PHP返回xml代码:header('content-type: t ...

  2. form组件之modelForm

    modelForm的使用及参数设置 从modelForm这个名字就能看出来,这个form是和模型类model有知己诶关联的,还是以数和出版社的模型来说明: models.py(模型) from dja ...

  3. Ansible故障

    常见问题一: [root@m01 ~]# ansible  -k 172.16.1.51 -m ping SSH password: [WARNING]: No hosts matched, noth ...

  4. 阿里Java开发规约(1)

    本文是对阿里插件中规约的详细解释一,关于插件使用,请参考这里 1. ArrayList的subList结果不可强转成ArrayList,否则会抛出ClassCastException异常. 说明:禁止 ...

  5. 问题:jQuery中遍历XML文件时候,获取子节点children不支持的情况(已解决)

    问题描述: 今天在写一个基于 jquery 的读取xml文件的程序时候,需要遍历xml的节点. 代码片段如下: function parse_xml_node(parent,result){ // r ...

  6. sf04_操作系统中 heap 和 stack 的区别

    概述 本文分三部分,描述有所重叠,但可以让你对栈与堆有一个比较清晰.全面的认识 heap 和 stack是什么 堆栈是两种数据结构.堆栈都是一种数据项按序排列的数据结构,只能在一端(称为栈顶(top) ...

  7. mysql初始化

    注意:--install前,必须用mysql启动命令的绝对路径 # 制作MySQL的Windows服务,在终端执行此命令: mysqld --install # 移除MySQL的Windows服务,在 ...

  8. hive - load CSV file NULL value 加载csv文件出现结果全是空值

    这个问题的根源是,创建表的时候没有指定列分隔符还有行分隔符. 因此修改建表语句 问题依然重现,此问题苦恼了一个下午,有一次用describe tablename 发现了问题所在,原来是一直没有删除ta ...

  9. socket编程(一)

    因为下载器涉及到socket的知识,就花了一天学习了.因为时间原因分成几部分.(这里记录上的是基于Windows平台的) #include <stdio.h> #include <w ...

  10. Qt 日志输出

    Qt学习(3)日志输出 普通的打印输出 用 QtCreator 开发 Qt 程序时, 经常需要向控制台打印一些参数.有时候是查看对象的属性是否被正确设置,有时候是查看程序是否执行了某一段代码,或者执行 ...