FizzBuzz問題の解答例 MySQL編

MySQLによるFizzBuzz問題の解答例。

解答例

条件分岐とループによるプログラム:

/*
  fizzbuzz.txt

  実行方法:
  mysql> SOURCE fizzbuzz.txt

  MySQL 5.1で動作確認
*/

CREATE DATABASE db_fizzbuzz;
USE db_fizzbuzz;
CREATE TABLE tb_fizzbuzz (result VARCHAR(10));

DELIMITER //
CREATE PROCEDURE fizzbuzz(n INT)
BEGIN
  DECLARE i INT DEFAULT 1;
  WHILE i <= n DO
    IF (i % 3 = 0) && (i % 5 = 0) THEN  -- iが3の倍数かつ5の倍数
      INSERT INTO tb_fizzbuzz VALUES("Fizz,Buzz");
    ELSEIF i % 3 = 0 THEN  -- iが3の倍数(かつ、5の倍数でない)
      INSERT INTO tb_fizzbuzz VALUES("Fizz");
    ELSEIF i % 5 = 0 THEN  -- iが5の倍数(かつ、3の倍数でない)
      INSERT INTO tb_fizzbuzz VALUES("Buzz");
    ELSE  -- iが3の倍数でも5の倍数でもない
      INSERT INTO tb_fizzbuzz VALUES(i);
    END IF;
  SET i = i + 1;
  END WHILE;
END
//
DELIMITER ;

CALL fizzbuzz(100);

SELECT * from tb_fizzbuzz;

DROP PROCEDURE fizzbuzz;
DROP TABLE tb_fizzbuzz;
DROP DATABASE db_fizzbuzz;

ストアドプロシージャの再帰呼び出しによるプログラム:

/*
  fizzbuzz_rc.txt

  my.cnfの設定:
  [mysqld] の下に次の項目を追加。
  max_sp_recursion_depth = 128
  thread_stack = 512K

  実行方法:
  mysql> SOURCE fizzbuzz_rc.txt

  MySQL 5.1で動作確認
*/

CREATE DATABASE db_fizzbuzz;
USE db_fizzbuzz;
CREATE TABLE tb_fizzbuzz (result VARCHAR(10));

DELIMITER //
CREATE PROCEDURE fizzbuzz(n INT)
BEGIN
  IF n > 1 THEN
    CALL fizzbuzz(n-1);
  END IF;

  IF (n % 3 = 0) && (n % 5 = 0) THEN  -- nが3の倍数かつ5の倍数
    INSERT INTO tb_fizzbuzz VALUES("Fizz,Buzz");
  ELSEIF n % 3 = 0 THEN  -- nが3の倍数(かつ、5の倍数でない)
    INSERT INTO tb_fizzbuzz VALUES("Fizz");
  ELSEIF n % 5 = 0 THEN  -- nが5の倍数(かつ、3の倍数でない)
    INSERT INTO tb_fizzbuzz VALUES("Buzz");
  ELSE  -- nが3の倍数でも5の倍数でもない
    INSERT INTO tb_fizzbuzz VALUES(n);
  END IF;
END
//
DELIMITER ;

CALL fizzbuzz(100);

SELECT * from tb_fizzbuzz;

DROP PROCEDURE fizzbuzz;
DROP TABLE tb_fizzbuzz;
DROP DATABASE db_fizzbuzz;

【theme : プログラミング
【genre : コンピュータ

プロフィール

よしいず

Author:よしいず
MATHEMATICS.PDFというウェブサイトを運営しています。

管理の都合上、トラックバックとコメントはオフにしてあります。ブログ経験者なら分かっていただけると思いますが、スパム(アダルトやその他の宣伝)ばかりなのが現実です。

リンクは自由です。当サイトの記事に対する間違いの指摘・意見・感想などを述べた記事からのリンクは歓迎です。ただし、ブログ記事アップ直後はミスが多く、頻繁に修正します。場合によっては削除する可能性もあります。その際、何も断りもなく修正・削除しますがご了承ください。内容を参考にする場合には投稿後一週間ほど様子を見てからにしてください(笑)。

記事の間違いを指摘するときは、その具体的箇所、理由(仕様に反するなど)・根拠(参考にした文献など)、代替案(同じ結果を得るための正しいやり方)も教えてください。そうしないと、(指摘される側および第三者はその時点では無知の状態なので、)どこが間違いなのか分かりませんし、本当に間違っているのかどうかが判断・検証できません。実際、間違いだと指摘されたことが結局は正しかったというケースもありますので。

このブログのタイトル一覧

リンク
月別アーカイブ
カテゴリ
最新記事
検索フォーム
RSSリンクの表示