コマンドラインからストアドプロシージャを呼び出すにはどうすればよいですか?
手順があります:
CREATE DEFINER=`root`@`localhost` PROCEDURE `insertEvent`(IN `dateTimeIN` DATETIME)
NO SQL
BEGIN
SET @eventIDOut = NULL;
IF EXISTS(SELECT * FROM `events` WHERE `eventDate` = dateTimeIN) THEN
SELECT `eID` INTO @eventIDOut FROM `events` WHERE `eventDate` = dateTimeIN LIMIT 1;
ELSE
INSERT INTO `events` (`eventDate`) VALUES(dateTimeIN);
SET @eventIDOut = last_insert_id();
END IF;
SELECT CONCAT(@eventIDOut);
END
私はこれを試しました:mysql> CALL insertEvent(2012.01.01 12:12:12);
結果:
エラー1064(42000):SQL構文にエラーがあります。 1行目で '.01 12:12:12)'の近くで使用する正しい構文については、MySQLサーバーのバージョンに対応するマニュアルを確認してください。
そしてこれ:mysql> CALL insertEvent
-> 2012.01.01 12:12:12;
結果:
エラー1064(42000):SQL構文にエラーがあります。 2行目で '2012.01.01 12:12:12'の近くで使用する正しい構文については、MySQLサーバーのバージョンに対応するマニュアルを確認してください。
日付を引用符で囲む:
mysql> CALL insertEvent('2012.01.01 12:12:12');