#结束符号默认;, delimiter $$语句表示结束符号变更为$$ delimiter $$ CREATE PROCEDURE `demo`(IN inStr VARCHAR(100), out ourStr VARCHAR(4000)) BEGIN SET ourStr = '01'; if (inStr == '02') then set ourStr = '02'; end if; END$$ #结束符号修改 delimiter ;
(1)註解方式
// key1和key2都是参数map中的key // key1是需要传入存储过程的值 // key2是用于接收存储过程返回的值,跟获取自增主键类似 @Select("call demo('${key1}', #{key2, mode=OUT, jdbcType=VARCHAR})") @Options(statementType = StatementType.CALLABLE) String getDemoValue(Mapmap);
(2)xml方式
就簡單的一個預存程序
BEGIN #SELECT COUNT(*) scount FROM test_user t WHERE t.user_sex=sex; SELECT user_name userName FROM test_user t WHERE t.user_sex=sex; END
然後在Mybatis Mapper設定檔中
然後userName值null,這是為什麼呢?在mapper.xml檔會做映射處理,而在預存程序中下方標紅的屬性 user_name並不會自動映射到userName 值中,所以呼叫userName值一定會回傳null。
BEGIN #SELECT COUNT(*) scount FROM test_user t WHERE t.user_sex=sex; SELECT user_name userName FROM test_user t WHERE t.user_sex=sex; END
那要怎麼處理這樣問題呢?那就是加上INTO 關鍵字
BEGIN #SELECT COUNT(*) scount FROM test_user t WHERE t.user_sex=sex; SELECT user_name INTO userName FROM test_user t WHERE t.user_sex=sex; END
以上是mybatis怎麼呼叫mysql預存程序並取得回傳值的詳細內容。更多資訊請關注PHP中文網其他相關文章!