MySQL用rand函数实现随机数

SELECT FLOOR(7 + ( RAND() * 6)); 在一定范围随机产生一个数字

有朋友问到如何在mysql中使用随机数

如何写一个语句能一下更新几百条MySQL数据!

需要测试MyQL数据库,里面有一个上万条数据的数据库,如何写一个PHP文件一下每次更新几百条信息,我都是写一个循环一次更新一条信息,这样我知道用WHILE写就可以了,要是一次更新好比100条数据该如何写呢?

正确答案是: UPDATE cdb_posts SET views = rand();

MySQL示例:

示例1:select * from tableA order by rand() limit 5;

    测试一下才发现这样效率非常低。一个15万余条数据,居然要8秒以上。

    查看官方手册,也说rand()放在order by字句中会被执行多次,自然效率很低。You can't use a column with rand() values in an ORDER BY clause, because ORDER BY wolud evaluate the column multiple times.

搜索Google,网上基本是那个都是查询max(id)* rand来随机获取数据。

示例2:

SELECT *

FROM tableA AS A1

JOIN (SELECT ROUND(RAND() * (SELECT MAX(id) FROM tableA)) AS a2_id) AS A2

WHERE A1.id >= A2.a2_id

ORDER BY A1.id ASC

LIMIT 5;

但是这样会产生连续的5条记录。解决办法只能是每次查询一条,查询5次。即便如此也值得,因为15万的表,查询只需要0.01秒不到。

上面的语句采用的是JOIN,mysql的论坛上有人使用

实例3:

SELECT *

FROM tableA

WHERE id>=(SELECT FLOOR(MAX(id) * RAND()) FROM tableA)

ORDER BY id

LIMIT 5;

测试一下,需要0.5秒,速度也不错,但是跟上面的语句还是有很大的差距。总觉得有什么地方不正常。

把示例3中的语句改写一下

示例4:

SELECT *

FROM tabelA

WHERE id >= (SELECT FLOOR(RAND() * (SELECT MAX(id) FROM tableA)))

ORDER BY id

LIMIT 5;

这下,效率又提高了,查询时间只有0.01秒

最后,再把语句完善一下,加上MIN(id)的判断。我在开始测试的时候,就是因为没有加上MIN
(id)的判断,结果有一半的时间总是查询到表中的前面几行,完整的查询语句如下:

示例5:

SELECT *

FROM tableA

WHERE id >= (SELECT FLOOR(RAND() * ((SELECT MAX(id) FROM tableA) - (SELECT MIN(id) FROM tableA)) + (SELECT MIN(id) FROM tableA)))

ORDER BY id

LIMIT 5;

示例6:

SELECT *

FROM tableA as a1

JOIN (SELECT ROUND(RAND() * ((SELECT MAX(id) FROM tableA) - (SELECT MIN(id) FROM tableA)) + (SELECT MIN(id) FROM tableA)) AS a2_id)  AS a2

ORDER BY id

LIMIT 5;

最后在php中对这两个语句进行分别查询10次,

示例5花费的时间0.147433 秒

示例6花费的时间 0.015130 秒

看来采用JOIN的语法比直接在WHERE 中使用函数效率还要高很多

你可能感兴趣的:(MySQL用rand函数实现随机数)