phpMyAdminからストアドプロシージャを作成したいのですが、エラーが表示され作成できません。
DELIMITER //
CREATE PROCEDURE proc1(INT pa char(10))
BEGIN
update sum_table set blank = pa;
END;
//
DELIMITER ;
これを実行したところ以下のエラーが出ました。
#1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'INT pa char(10)) BEGIN update sum_table set blank = pa; END' at line 1
--------------------------------------------------------------------------------
そこでソースから「DELIMITER」を消してもう一度実行してみました。
CREATE PROCEDURE proc1(INT pa char(10))
BEGIN
update sum_table set blank = pa;
END;
すると今度は以下のエラーが表示されました。
#1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'INT pa char(10))
BEGIN
update sum_table set blank = pa' at line 1
どこが間違っているかわからず困っております。
初歩的な質問で凝縮ですが、どなたかご教示いただけますでしょうか?
No.1ベストアンサー
- 回答日時:
まずそのpaはINTなの、char(10)なの。
INTならDELIMITER //
CREATE PROCEDURE proc1(pa INT)
BEGIN
update sum_table set blank = pa;
END;
//
DELIMITER ;
やし、char(10)なら
DELIMITER //
CREATE PROCEDURE proc1(pa char(10))
BEGIN
update sum_table set blank = pa;
END;
//
DELIMITER ;
とすれば通るのではないかな。多分INTはINの間違いなのだと思うのだが・・・・。
>まずそのpaはINTなの、char(10)なの。
char型です。
>とすれば通るのではないかな。多分INTはINの間違いなのだと思うのだが・・・・。
おっしゃるとおりINTではなくINの間違いでした。
ご指摘の通り下のように書き直したところ正常に処理できました。
DELIMITER //
DROP PROCEDURE IF EXISTS proc1//
CREATE PROCEDURE proc1(in pa char(10))
BEGIN
update sum_table set blank = pa;
END;
//
DELIMITER ;
そして下記のコマンドで確認したところ、ストアドプロシージャの存在を確認できました。
SHOW PROCEDURE STATUS;
非常に助かりました(#^^#)
ありがとうございました(#^.^#)
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- MySQL 何にかが違うから エラーなんでしょうね! 2 2022/09/18 05:28
- MySQL MySQLのテーブル作成でハイフン - は使用できないのでしょうか? 2 2022/10/21 16:50
- MySQL テーブル作成です。どこかのスペルが間違っているか記号など スペースかな? 1 2022/10/01 05:08
- MySQL 参考書に従って入力したつもりでしたが、最後はエラーがでました。 1 2022/09/28 03:45
- PHP php エラー 2 2022/10/23 16:43
- 英語 英文の添削お願いします。【長文です。】 マッチングアプリで相手を言い負かしている時のやつです。 色々 1 2023/07/01 02:12
- その他(SNS・コミュニケーションサービス) 自分のpcがハッキングされたようなメールが来たのですがどうすればいいですか? 4 2022/10/02 16:14
- VPN 何これ 1 2022/04/19 01:32
- 戦争・テロ・デモ ウクライナ、メル友に五千円要求されてさ 1 2022/04/02 09:38
- 公的扶助・生活保護 保証人? 1 2022/05/17 22:42
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
fgetsなどのときのstdinのバッ...
-
ftoa の作り方
-
C言語のfor文です。 繰り返しの...
-
エンディアン:2バイトのデー...
-
絶対パスからのファイル名の切...
-
テキストデータをそのままバイ...
-
charでの計算?
-
strtol関数 自作
-
C言語の入力した文字を反転させ...
-
3桁区切(コンマ)記号をつけ...
-
「ポインタのポインタ」を使っ...
-
【C言語】文字型と整数型の違い
-
コマンドラインに入力されてい...
-
c言語配列の結合についてです。...
-
配列をnビットシフトする
-
str系関数を使わずに二つの文字...
-
【C言語】構造体内の領域解放(...
-
文字列から空白を取り除きたい...
-
atoi( ) の反対をやりたい
-
OpenCVで32bit ヘッダ無しRaw画...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
charからLPTSTRへの変換方法
-
charでの計算?
-
配列をnビットシフトする
-
'const char *' 型は 'char *' ...
-
型変換
-
テキストデータをそのままバイ...
-
文字列から空白を取り除きたい...
-
CStringをwchar_tに変換したい
-
絶対パスからのファイル名の切...
-
fgetsなどのときのstdinのバッ...
-
ネットワークにつながっている...
-
str系関数を使わずに二つの文字...
-
3桁区切(コンマ)記号をつけ...
-
atoi( ) の反対をやりたい
-
double型の値をchar配列に変換...
-
C言語のfor文です。 繰り返しの...
-
switch文で文字を比較すること...
-
ファイル名である文字列からbas...
-
c++ 文字列を入力して、一文字...
-
strncpyと_tcsncpy_sのヌルの扱...
おすすめ情報