MySQL
 Computer >> コンピューター >  >> プログラミング >> MySQL

MySQLテーブルから固定数のランダムレコードを選択しますか?


ランダムレコードの場合、rand()メソッドを使用できます。レコード数を設定するには、LIMIT-

を使用します
select *from yourTableName order by rand() limit numberOfRecords;

まずテーブルを作成しましょう-

mysql> create table DemoTable
   -> (
   -> LastName varchar(100)
   -> );
Query OK, 0 rows affected (0.51 sec)

挿入コマンド-

を使用して、テーブルにいくつかのレコードを挿入します
mysql> insert into DemoTable values('Brown');
Query OK, 1 row affected (0.20 sec)

mysql> insert into DemoTable values('Smith');
Query OK, 1 row affected (0.13 sec)

mysql> insert into DemoTable values('Taylor');
Query OK, 1 row affected (0.10 sec)

mysql> insert into DemoTable values('Miller');
Query OK, 1 row affected (0.15 sec)

mysql> insert into DemoTable values('Johnson');
Query OK, 1 row affected (0.20 sec)

selectステートメントを使用してテーブルのすべてのレコードを表示する-

mysql> select *from DemoTable;

出力

これにより、次の出力が生成されます-

+----------+
| LastName |
+----------+
| Brown    |
| Smith    |
| Taylor   |
| Miller   |
| Johnson  |
+----------+
5 rows in set (0.00 sec)

以下は、固定数のランダムレコードを選択するためのクエリです-

mysql> select *from DemoTable order by rand() limit 4;

出力

これにより、次の出力が生成されます-

+----------+
| LastName |
+----------+
| Brown    |
| Miller   |
| Johnson  |
| Taylor   |
+----------+
4 rows in set (0.03 sec)

  1. MySQLのストアドプロシージャからのテーブルレコードを表示する

    まずテーブルを作成しましょう- mysql> create table DemoTable1933    (    ClientName varchar(20)    ); Query OK, 0 rows affected (0.00 sec) 挿入コマンド-を使用して、テーブルにいくつかのレコードを挿入します mysql> insert into DemoTable1933 values('Chris Brown'); Query OK, 1 row affected (0.00 sec) mysql

  2. MySQLで特定の番号が含まれている場合は、すべてのレコードを選択しますか?

    このためには、LIKEと一緒にconcat()を使用します。以下は構文です- select *from yourTableName where concat(',', yourColumnName, ',') like '%,yourValue,%'; テーブルを作成しましょう- mysql> create table demo49 −> ( −> id varchar(20) −> , −> first_name varchar(20) −> );