mybatis はどのようにして mysql ストアド プロシージャを呼び出し、戻り値を取得しますか

王林
リリース: 2023-05-27 09:01:30
転載
1886 人が閲覧しました

mybatis は mysql ストアド プロシージャを呼び出し、戻り値を取得します

1、mysql はストアド プロシージャを作成します

#结束符号默认;, 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 ;
ログイン後にコピー

2、mybatis は

(1) アノテーション メソッド

を呼び出します
// key1和key2都是参数map中的key // key1是需要传入存储过程的值 // key2是用于接收存储过程返回的值,跟获取自增主键类似 @Select("call demo('${key1}', #{key2, mode=OUT, jdbcType=VARCHAR})") @Options(statementType = StatementType.CALLABLE) String getDemoValue(Map map);
ログイン後にコピー

(2)xml メソッド

ログイン後にコピー

Mybatis はストアド プロシージャの呼び出し時に null 値を返すという落とし穴に遭遇します

Mybatis はストアド プロシージャの呼び出し時に 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
ログイン後にコピー
ログイン後にコピー

次に、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 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:yisu.com
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!