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

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

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

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

MyBatis

MyBatisはJavaや.NET Frameworkでなどで使用できる、SQL文や、ストアドプロシージャをオブジェクトと紐付けるO/Rマッピングフレームワークです。

Q&A

解決済

1回答

44668閲覧

myBatisで、IN句を用いたい

king_yamada

総合スコア117

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

MyBatis

MyBatisはJavaや.NET Frameworkでなどで使用できる、SQL文や、ストアドプロシージャをオブジェクトと紐付けるO/Rマッピングフレームワークです。

0グッド

0クリップ

投稿2014/08/30 02:17

myBatisで、SQLのIN句の中に複数の値を渡したいSQLがあります。

lang

1SELECT * FROM tblA WHERE colhoge IN(1,2,5);

のような形のSQLを書きたいです。
どのようにすればいいのでしょうか?
分かる人、教えて下さい。

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

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

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

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

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

guest

回答1

0

ベストアンサー

foreachを使うとできます。

lang

1#DAO 2List<tblA> selectHoge(@Param("hoges") List<Integer> listHoge);

lang

1#XML 2<select id="selectHoge" resultType="com.fuga.hoge" parameterType="List"> 3 SELECT * 4 FROM tblA 5 WHERE colhoge in 6 <foreach item="hoge" collection="hoges" 7 open="(" separator="," close=")"> 8 #{hoge} 9 </foreach> 10</select>

のような形がサンプルです。()で自動的に囲んでくれます。

投稿2014/09/01 02:18

monster1012

総合スコア82

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

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

muroiken

2014/09/02 02:22

ibatis時代の<iterate>はmyBatisでは使えなくなったので、注意が必要ですね。 構文はほぼ同じですが。
monster1012

2014/09/02 02:47

ちなみに、動的SQLを書く時は、foreach以外でも if choose, when, otherwise where set trim なども使えます。これらについても覚えるといいでしょう。
king_yamada

2014/09/02 07:24

分かりやすいサンプル、勉強になりました。 ibatisからmyBatisになって構文が変わったのですね。 他の動的SQLについても勉強してみようと思います。 ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問