• MySQL完成表中掏出随机数据


      泉源:站长资讯  




    从前在群里批判辩论过这个题目,对比的存心思.mysql的语法真好玩.他们原本都想用PHP的完成随机,但掏出多条好像要终了两次以上盘考.翻了手册,找到了下面这个语句,可以完成使命了。

    SELECT * FROM table_name ORDER BY rand() LIMIT 5;

      rand在手册里是这么说的:
      RAND()
      RAND(N)
      前去在领域0到1.0内的随机浮点值。假如一个整数参数N被指定,它被用作种子值。

    mysql> select RAND();
    -> 0.5925
    mysql> select RAND(20);
    -> 0.1811
    mysql> select RAND(20);
    -> 0.1811
    mysql> select RAND();
    -> 0.2079
    mysql> select RAND();
    -> 0.7888

      你不能在一个ORDER BY子句用RAND()值行使列,由于ORDER BY将重复计算列多次。可是在MySQL3.23中,你可以做: SELECT * FROM table_name ORDER BY RAND(),这是有利于掉掉一个来自SELECT * FROM table1,table2 WHERE a=b AND c<d ORDER BY RAND() LIMIT 1000的集合的随机样本。寄望在一个WHERE子句里的一个RAND()将在每次WHERE被执行时重新评价。

      但我试了一下,8千笔记载的表,执行一次需要0.08 sec,.慢了些

      厥后就教了google,掉掉如下代码

    SELECT * FROM table_name AS r1 JOIN ( SELECT ROUND(RAND() * (SELECT MAX(id) FROM table_name)) AS id) AS r2 WHERE r1.id >= r2.id ORDER BY r1.id ASC LIMIT 5;





    版权声明: 原创作品,容许转载,转载时请务必以超链接编制标明文章 原始理由 、作者信息和本声明。不然将清查纪律责任。

  • 相关阅读:
    安卓系统浏览器中select下拉按钮无法弹出选择面板奇怪问题解决
    Webkit浏览器点击控件时出现的边框消除
    UML序列图总结
    UML序列图总结
    UML类图几种关系的总结
    UML类图几种关系的总结
    UML用例图总结
    UML用例图总结
    类与类之间的关系
    java核心技术----Object类
  • 原文地址:https://www.cnblogs.com/zgqjymx/p/1975713.html
Copyright © 2020-2023  润新知