zoukankan      html  css  js  c++  java
  • mysql高效率随机获取n条数据写法

    今天做项目遇到这个问题,本来想用mysql自带的随机函数来实现,但是想到这样做功能是实现了,但是效率真的好差!一下子想不到好的方法,就去网上找了一下,记录下来,好好研究学习一下。

    ID连续的情况下(注意不能带where,否则结果不好):

    SELECT *
    FROM `talbe` AS t1 JOIN (SELECT ROUND(RAND() * (SELECT MAX(id) FROM `table`)) AS id) AS t2
    WHERE t1.id >= t2.id
    ORDER BY t1.id ASC LIMIT 4;

    ID不连续的情况下:

    SELECT * FROM `table` 
    WHERE id >= (SELECT floor(RAND() * (SELECT MAX(id) FROM `table`)))  and a = "a" and b = b
    ORDER BY id LIMIT 4;

    假设你的表叫做mm_account,并且有一个字段叫id。最快的方法如下(随机获取5条):

    SELECT * FROM talbe WHERE id >= ((SELECT MAX(id) FROM table)-(SELECT MIN(id) FROM table)) * RAND() + (SELECT MIN(id) FROM table) limit 5;

    如果带where语句,上面就不适合了。带where语句请看下面:

    SELECT *
    FROM `table` AS t1 JOIN (SELECT ROUND(RAND() * (
    (SELECT MAX(id) FROM `table` where id < 1000 )-(SELECT MIN(id) FROM `table` where id < 1000 ))+(SELECT MIN(id) FROM `table` where id < 1000 )) AS id) AS t2
    WHERE t1.id >= t2.id
    ORDER BY t1.id LIMIT 5;
  • 相关阅读:
    (C#)asp_net调试错误解决方法收集(1)
    asp.net调试技巧
    asp。Net 页面传值
    viewState详解
    Session,ViewState用法
    asp.net中通过form表单submit提交到后台的实例
    C#读写xml文件
    Asp.Net前台调用后台变量
    3. mybatis # 与 $ 的区别
    IDEA 中 使用 git(Git)
  • 原文地址:https://www.cnblogs.com/firstlady/p/9896359.html
Copyright © 2011-2022 走看看