質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
CentOS

CentOSは、主にRed Hat Enterprise Linux(RHEL)をベースにした、フリーのソフトウェアオペレーティングシステムです。

MySQL Workbench

MySQL Workbenchは、オープンソースのデータベースモデリングツールです。ビジュアルなデータベース設計・SQL開発・サーバー設定・ユーザー管理・バックアップといった様々な管理ツールを備えます。

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Linux

Linuxは、Unixをベースにして開発されたオペレーティングシステムです。日本では「リナックス」と呼ばれています。 主にWebサーバやDNSサーバ、イントラネットなどのサーバ用OSとして利用されています。 上位500のスーパーコンピュータの90%以上はLinuxを使用しています。 携帯端末用のプラットフォームAndroidは、Linuxカーネル上に構築されています。

Q&A

解決済

1回答

1092閲覧

mysqlのプロシージャからshellに戻り値を返す方法

s_ayana

総合スコア35

CentOS

CentOSは、主にRed Hat Enterprise Linux(RHEL)をベースにした、フリーのソフトウェアオペレーティングシステムです。

MySQL Workbench

MySQL Workbenchは、オープンソースのデータベースモデリングツールです。ビジュアルなデータベース設計・SQL開発・サーバー設定・ユーザー管理・バックアップといった様々な管理ツールを備えます。

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Linux

Linuxは、Unixをベースにして開発されたオペレーティングシステムです。日本では「リナックス」と呼ばれています。 主にWebサーバやDNSサーバ、イントラネットなどのサーバ用OSとして利用されています。 上位500のスーパーコンピュータの90%以上はLinuxを使用しています。 携帯端末用のプラットフォームAndroidは、Linuxカーネル上に構築されています。

0グッド

1クリップ

投稿2018/01/17 05:15

編集2018/01/17 05:57

現在workbenchのほうでプロシージャを作りました。
この作ったプロシージャにShellから繋げてプロシージャの例外処理の結果をShellに返す方法を知りたいです。

ソース MYSQLworkbench

DELIMITER $$
DROP PROCEDURE IF EXISTS testproc1$$
CREATE PROCEDURE testproc1()
BEGIN
DECLARE done INT;
DECLARE CONTINUE HANDLER FOR SQLSTATE '21000' SET done = 0;
SET @num=(SELECT a_tensou FROM a_c_info);
SET @path=(select s_nm3 from s_system where s_Key2 = 12);
IF @num=2 THEN
SET @query = CONCAT('SELECT * FROM a_c_info where a_tensou = 2 INTO OUTFILE ',"'", @path ,"'",' FIELDS TERMINATED BY ","');
PREPARE getExtends FROM @query;
EXECUTE getExtends;
DEALLOCATE PREPARE getExtends;
SET SQL_SAFE_UPDATES = 0;
update a_c_info set a_tensou=3 where a_tensou=2;
END IF;
END$$
DELIMITER ;

このソースはざっくりと説明するとa_tensouカラムに2という数字が入ったら、csvファイルを出力してカラム3に変換するというコードです。
DECLARE CONTINUE HANDLERは error 1241 サブクエリエラーを処理しています。

そしてshellからこのストアドプロシージャが呼び出された時、正常なら0 なにかエラーなら1という戻り値を返したいのですがやり方わかるかたいたらよろしくお願いします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

例外処理をいれるということは常に正常終了をするということです。
したがって例外を通らないものはselect 1 as ret;
(retは戻り値的な意味合いなので実際にはなんでもいいです)
例外処理されたものはselect 0 as ret;
のようなtrue/falseを返す処理をすれば、
その値をもって分岐させることはできるでしょう。

投稿2018/01/17 05:31

yambejp

総合スコア114769

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問