可爱熊个人博客

Archive for 十二月, 2010

mysql 更新随机数的办法

例子:

update dede_arcgame set gclick=FLOOR(RAND()*50) where gclick=’1′

1.mysql产生随机数并与字符串想加组成新的字符串:

update `list`  set email=concat(RAND(50),`@126.com`) WHERE id>100;

2.mysql高效随机产生相邻5条记录方法::

SELECT *
FROM `list` AS tt1 JOIN (SELECT ROUND(RAND() * ((SELECT MAX(id) FROM `list`)-(SELECT MIN(id) FROM `list`))+(SELECT MIN(id) FROM `list`)) AS id) AS tt2
WHERE tt1.id >= tt2.id
ORDER BY tt1.id LIMIT 5;

RAND() RAND(N)
返回一个随机浮点值 v ,范围在 0 到1 之间 (即, 其范围为 0 ≤ v ≤ 1.0)。若已指定一个整数参数 N ,则它被用作种子值,用来产生重复序列, 返回-5至5的随机整数.在PHP中,则非常简单直接用.

<?php
print rand(-5,5);
?>

在mysql中,rand函数只能有一个参数.利用MySQL的ROUND()加上RAND()函数实现:

//0.5-rand()可以得到-0.5 至 +0.5的随机数
//(0.5-rand())*2可以得到-1 至 +1的随机数
//(0.5-rand())*2*5可以得到-5 至 +5的随机数
//ROUND((0.5-RAND())*2*5)可以得到-5 至 +5的随机整数

优点: 当随机数范围很广的时候,只需要更改*5当中的5即可,非常方便.
缺点: 随机数只能是连续的,不可以指定某部分数据.

Tags: ,

今天发现update的新用法,可以在两表之间进行,效率很高

今天发现update的新用法,可以在两表之间进行,效率很高。

update A,B set A.A2 = B.B2 where A.A1 = B.B1 and B.B2 = "XXX"

Tags: