在mysql中我們要查詢數據表中隨機數據最常用的就是使用Rand()函數了,但是Rand()函數在使用幾萬條記錄是很快的,如果上千萬條時可能會有問題,下面我來介紹Rand()函數的用法.
MySQL隨機查詢出一條記錄,代碼如下:
- $sql = “SELECT * FROM pinglun WHERE id >= ((SELECT MAX(id) FROM pinglun)-(SELECT MIN(id) FROM pinglun)) * RAND() + (SELECT MIN(id) FROM pinglun) LIMIT 1″;
這樣寫效率比較高,千萬不要用order by rand()那種,數據量大了,order一下效率很低,下面我來介紹一下 隨機取出記錄的優化.
第一種方法:結合應用層來實現,只要SELECT MAX(id) FROM table;取出最大的id,然后用隨機生成一個1~MAX(id)數,比如PHP mt_rand(1,MAX(id)) 然后再在用這個隨機id去查詢那條記錄.
第二種方法:利用數據庫生成的隨機的id,子查詢的方式,代碼如下:
SELECT CEIL(RAND() * (SELECT MAX(id) FROM table));
這樣我們就可以獲取一個隨機的id.(對MAX()進行優化,不使用SELECT CEIL(RAND() * MAX(id)) FROM table),執行一下,大大優化了,代碼如下:
- SELECT *
- FROM table
- WHERE id >= (
- SELECT CEIL( RAND( ) * (
- SELECT MAX( id )
- FROM table ) ) )
- LIMIT 1
第三種方法:利用JOIN的方法,代碼如下:
- SELECT *
- FROM `table` 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 1 --Vevb.com
新聞熱點
疑難解答