温馨提示×

Mybatis foreach怎样实现复杂查询

小樊
83
2024-07-16 11:17:44
栏目: 编程语言

Mybatis的foreach标签可以用于动态生成IN语句,从而实现复杂查询。以下是一个示例:

假设我们有一个用户实体类User,包含id和name属性。现在我们想要根据一组id查询用户信息。

首先在Mapper.xml中编写一个select语句,使用foreach标签动态生成IN语句:

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

然后在对应的Mapper接口中定义一个方法:

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

在调用该方法时,可以传入一个包含id的List:

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

这样就可以根据一组id查询到对应的用户信息了。通过foreach标签,我们可以灵活地生成IN语句,实现复杂的查询需求。

0