mysql随机抽取一定数量的记录实例讲解

 更新时间:2019年09月06日 15:13:28   作者:沉默的土豆  
在本篇文章里小编给大家整理的是关于mysql随机抽取一定数量的记录实例相关知识点,有需要的朋友们可以学习下。

以前碰见这种使用场景都是直接order by rand()来处理的,但是效率实在是不敢恭维,所以最近又碰见这种场景,在网上找寻下比较好的解决办法.

1.order by rand()

写法:

SELECT
  id
FROM
  `table`
ORDER BY
  rand()

这种写法的缺点是rand函数在order by中被执行多次,影响效率。

2.max(id) * rand() 使用join

写法:

SELECT
  *
FROM
  `table` AS t1
JOIN (
  SELECT
    ROUND(
      RAND() * (
        (SELECT MAX(id) FROM `table`) - (SELECT MIN(id) FROM `table`)
      ) + (SELECT MIN(id) FROM `table`)
    ) AS id
) AS t2
WHERE
  t1.id >= t2.id
ORDER BY
  t1.id
LIMIT 1;

网上的大佬们都推荐第二种写法,特此记录下,感觉最大id和最小id可以放在程序里来计算。

这里有个问题是如果取多条 那么一定是连续的,所以如果是不想取连续数据,得循环,不过此语句效率极高,所以循环查询是可以做的。

以上就是全部相关知识点内容,有需要的朋友们可以学习下,感谢大家对脚本之家的支持。

相关文章

  • MySQL压测工具mysqlslap的介绍与使用

    MySQL压测工具mysqlslap的介绍与使用

    mysqlslap是mysql自带的一个性能压测工具,mysqlslap用于和其它的一些性能压测工具一样可以自己造数据进行压测。mysqlslap的报告比较简单主要体现在执行的时间方面,没有sysbench那样的tps、qps等更详细的包括。下面来一起看看关于mysqlslap的介绍和简单的使用示例。
    2016-09-09
  • mysql 存储过程中变量的定义与赋值操作

    mysql 存储过程中变量的定义与赋值操作

    昨天我们讲了mysql存储过程创建修改与删除,下面我们这篇教程是讲关于mysql存储过程中变量的定义赋值操作哦。
    2010-05-05
  • MySQL控制用户输错密码尝试次数

    MySQL控制用户输错密码尝试次数

    这篇文章主要介绍了MySQL如何控制用户输错密码尝试次数,文中给大家提到了死锁监控方法及处理方案,需要的朋友可以参考下
    2019-11-11
  • mysql分组取每组前几条记录(排名) 附group by与order by的研究

    mysql分组取每组前几条记录(排名) 附group by与order by的研究

    mysql分组取每组前几条记录(排名) 附group by与order by的研究,需要的朋友可以参考下
    2012-10-10
  • 深入了解MySQL中INSTR()函数的使用

    深入了解MySQL中INSTR()函数的使用

    本文主要介绍了深入了解MySQL中INSTR()函数的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-07-07
  • 一台电脑(windows系统)安装两个版本MYSQL方法步骤

    一台电脑(windows系统)安装两个版本MYSQL方法步骤

    由于新旧项目数据库版本差距太大,编码格式不同,引擎也不同,所以只好装两个数据库,这篇文章主要给大家介绍了关于一台电脑(windows系统)安装两个版本MYSQL的方法步骤,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2023-03-03
  • Mysql大小写敏感的问题

    Mysql大小写敏感的问题

    这篇文章主要介绍了Mysql大小写敏感的问题的相关资料,需要的朋友可以参考下
    2015-03-03
  • MySQL约束与索引概念详解

    MySQL约束与索引概念详解

    约束是用来对数据业务规则和数据完整性进行实施、维护。约束的作用范围仅限在当前数据库,约束可以被当做数据库对象来处理,它们具有名称和关联模式,是逻辑约束,不会因为设置约束而额外占用空间
    2023-04-04
  • Mysql双主配置的详细步骤

    Mysql双主配置的详细步骤

    双主可以在一定程度上保证主库的高可用,在一台主库down掉之后,可以在极短的时间内切换到另一台主库上,减少了主从同步给线上主库带来的压力,这篇文章主要给大家介绍了关于Mysql双主配置的详细步骤,需要的朋友可以参考下
    2022-06-06
  • 利用MySQL函数实现判断视频扩展名的代码

    利用MySQL函数实现判断视频扩展名的代码

    MySQL拥有强大的自定义函数功能,如下,我写了一个用MySQL函数 判断视频地址是否可以手机端播放
    2012-02-02

最新评论