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

MySQLストアドプロシージャで5つの乱数を生成するにはどうすればよいですか?


乱数を生成するには、MySQLのORDER BY RAND()関数を使用します。まずテーブルを作成しましょう-

mysql> create table DemoTable (Value int);
Query OK, 0 rows affected (0.76 sec)

挿入コマンド-

を使用して、テーブルにいくつかのレコードを挿入します
mysql> insert into DemoTable values(89);
Query OK, 1 row affected (0.19 sec)
mysql> insert into DemoTable values(98);
Query OK, 1 row affected (0.14 sec)
mysql> insert into DemoTable values(10);
Query OK, 1 row affected (0.34 sec)
mysql> insert into DemoTable values(78);
Query OK, 1 row affected (0.15 sec)
mysql> insert into DemoTable values(75);
Query OK, 1 row affected (0.14 sec)
mysql> insert into DemoTable values(76);
Query OK, 1 row affected (0.20 sec)
mysql> insert into DemoTable values(74);
Query OK, 1 row affected (0.16 sec)
mysql> insert into DemoTable values(99);
Query OK, 1 row affected (0.12 sec)
mysql> insert into DemoTable values(101);
Query OK, 1 row affected (0.15 sec)

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

mysql> select *from DemoTable;

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

+-------+
| Value |
+-------+
| 89    |
| 98    |
| 10    |
| 78    |
| 75    |
| 76    |
| 74    |
| 99    |
| 101   |
+-------+
9 rows in set (0.00 sec)

以下は、MySQLストアドプロシージャで5つの乱数を生成するためのクエリです-

mysql> DELIMITER //
mysql> CREATE PROCEDURE generate_Random5Numbers()
   BEGIN
      SELECT GROUP_CONCAT(Value SEPARATOR '/')
      FROM ( SELECT Value
         FROM ( SELECT Value
            FROM DemoTable
            WHERE Value BETWEEN 10 AND 100
         ORDER BY RAND()
         LIMIT 5) Ascending_Order
      ORDER BY Value) 5Values;
   END
   //
Query OK, 0 rows affected (0.31 sec)
mysql> DELIMITER ;

callコマンドを使用してストアドプロシージャを呼び出します。

mysql> call generate_Random5Numbers();

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

+-----------------------------------+
| GROUP_CONCAT(Value SEPARATOR '/') |
+-----------------------------------+
| 89/74/78/99/10                   |
+-----------------------------------+
1 row in set (0.00 sec)
Query OK, 0 rows affected (0.02 sec)

  1. MySQLストアドプロシージャに条件を正しく実装するにはどうすればよいですか?

    ストアドプロシージャで条件を設定するには、次の構文を使用します-     if yourCondition then    yourStatement1;      else    yourStatement2';       end if ;     end     // ストアドプロシージャで欠落しているセミコロンを修正するために、上記の構文を実装しましょう- mysql> delimiter // mysql>

  2. MySQLストアドプロシージャでDELIMITERを正しく使用するにはどうすればよいですか?

    正しい方法は次のとおりです- DELIMITER // CREATE PROCEDURE yourStoredProcedureName() BEGIN  IF  yourCondition then      yourStatement1 ; else     yourStatement2 ; END IF ; END // DELIMITER ; ここで例を見て、ストアドプロシージャを作成しましょう- mysql> DELIMITER // mysql> CREATE PROCEDURE delimit