勉強したことのメモ

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

MySQLでストアドプロシージャ戻り値対応版であるストアドファンクションの設定と利用方法

  MySQL データベース

先日MySQLのストアドプロシージャに関するメモを書いたが、今回はストアドファンクションについても色々試してみたい。ざっと調べたところ基本的には一連の処理を登録しておくと関数みたいに使える、とストアドプロシージャと同じっぽいが、ストアドファンクションは戻り値があるみたい。以下に設定を利用方法をメモ。

 

リファレンス

リファレンスについては以下を参照。

https://dev.mysql.com/doc/refman/8.0/ja/create-procedure.html

 

事前準備

以下のようなテーブル及びデータを用意した。

mysql> SHOW COLUMNS FROM `test_table`;
+------------+--------------+------+-----+---------+----------------+
| Field      | Type         | Null | Key | Default | Extra          |
+------------+--------------+------+-----+---------+----------------+
| id         | int          | NO   | PRI | NULL    | auto_increment |
| name       | varchar(255) | NO   |     | NULL    |                |
| score      | int          | NO   |     | NULL    |                |
| regist_ymd | datetime     | NO   |     | NULL    |                |
+------------+--------------+------+-----+---------+----------------+

mysql> SELECT * FROM `test_table`;
+----+-----------+-------+---------------------+
| id | name      | score | regist_ymd          |
+----+-----------+-------+---------------------+
|  1 | 鈴木      |    80 | 2024-02-15 18:13:49 |
|  2 | 佐々木    |    70 | 2024-02-15 18:20:11 |
|  3 | 山田      |    50 | 2024-02-21 12:47:20 |
+----+-----------+-------+---------------------+

 

設定方法

ストアドファンクションの追加

DELIMITER //
CREATE FUNCTION test_function() RETURNS DOUBLE DETERMINISTIC
BEGIN 
    DECLARE avg_score DOUBLE;
    SELECT AVG(`score`) INTO avg_score FROM `test_table`;
    RETURN avg_score;
END
//
DELIMITER ;

全score(点数)の平均値を返すという内容になる。

ストアドファンクションの確認

正常に設定されているかは以下で確認できる。

SHOW CREATE FUNCTION test_function;

ストアドファンクションの実行

mysql> SELECT test_function();
+-----------------+
| test_function() |
+-----------------+
|    66.666666666 |
+-----------------+

ストアドファンクションの削除

DROP FUNCTION test_function;

 - MySQL データベース

  関連記事

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

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

PHPからMySQLにシリアライズしたデータを格納

アンケートフォームみたいなのがあって、 今後も定期開催し、尚且つ質問内容は増減す ...

MySQLで1対多というテーブル構造でデータ結合と条件検索する方法

MySQLで飲食店舗テーブルと休業日テーブルがあり、1店舗に対して複数行の休業日 ...

MySQLでデータの集計時に1日の起点を任意の時間に変更する方法

MySQLで1日毎の集計を行う際、例えば2020/01/01のデータは2020/ ...

phpMyAdminでのエクスポート/インポート

DBのバックアップを取る際にエクスポート/インポートを行うが、 データ件数が多い ...