溫馨提示×

Mybatis foreach怎樣實現(xiàn)復雜查詢

小樊
83
2024-07-16 11:17:44
欄目: 編程語言

Mybatis的foreach標簽可以用于動態(tài)生成IN語句,從而實現(xiàn)復雜查詢。以下是一個示例:

假設(shè)我們有一個用戶實體類User,包含id和name屬性?,F(xiàn)在我們想要根據(jù)一組id查詢用戶信息。

首先在Mapper.xml中編寫一個select語句,使用foreach標簽動態(tài)生成IN語句:

<select id="selectUsersByIds" resultType="User">
    SELECT * FROM user
    WHERE id IN
    <foreach collection="ids" item="id" open="(" separator="," close=")">
        #{id}
    </foreach>
</select>

然后在對應(yīng)的Mapper接口中定義一個方法:

List<User> selectUsersByIds(List<Integer> ids);

在調(diào)用該方法時,可以傳入一個包含id的List:

List<Integer> ids = new ArrayList<>();
ids.add(1);
ids.add(2);
List<User> users = userMapper.selectUsersByIds(ids);

這樣就可以根據(jù)一組id查詢到對應(yīng)的用戶信息了。通過foreach標簽,我們可以靈活地生成IN語句,實現(xiàn)復雜的查詢需求。

0