勉強したことのメモ

Webエンジニア / プログラマが勉強したことのメモ。

MySQLでランダムにデータを取得しつつページング機能も実装する方法

   2024/04/18  PHP MySQL

MySQLからデータを持ってくる際にランダムな表示を行ってほしいと言われた。ただ、1ページあたり20件表示で、検索結果件数がそれ以上ならページをつけてほしいとのこと。調べたところMySQLのRAND()関数で解決した。以下に対応方法をメモ。

 

ソースコード

<?php
$rand = ( isset($_GET['rand']) && is_numeric($_GET['rand']) ) ? $_GET['rand'] : rand(1,100); //クエリが設定されればそれを引き回す。無ければ1-100の間でランダムな数値を設定する
$sql = '
    SELECT SQL_CALC_FOUND_ROWS *
    FROM testtable AS
    ORDER BY RAND(' . $rand . ')
    LIMIT ' . $offset . ',' . $limit
;

ページングの際に$randをクエリにつけてあげると上手いこといった。

 

参考サイト

http://satussy.blogspot.jp/2011/04/mysql.html?m=1

 - PHP MySQL

  関連記事

SSH接続でMySQLにダンプファイルをインポートする方法

phpMyAdminやAdminerが入っていなかったり、ダンプファイルのサイズ ...

MySQLでIPを整数値としてカラムに格納する

MySQLでIPを整数値としてカラムに格納しているケースがあった。今までIPが必 ...

MySQLでphpMyAdminやAdminer上だけ文字化けする場合の対応方法

レンタルサーバーのプログラムでWebページ上では文字化けしていないのに、phpM ...

MySQLで特定カラムの
タグを改行コードに一括置換させる方法

MySQLで特定カラムの<br>タグを改行コードに一括置換したかった ...

PHP / MySQLで2038年問題の対策

先日打ち合わせの際に「タイムスタンプを使ってユニークキーに云々~~」といったよう ...