Mybatis集合的嵌套Select查询

需求:

现有一张权益表、一张权益规则表,权益表和权益规则表是一对多的关系,即一个权益下有多条权益规则,
想在查询权益集合的时候同时查询出每个权益下的权益规则集合,即一个多对多的查询。

实现:

采用Mybatis集合的嵌套Select查询方式实现

查询结果javaBean

/**
 * @author chenqi
 * @version V1.0
 * @ClassName: GetEquityListVO
 * @Description: 根据权益分组查询权益集合接口VO
 * @Date 2019/10/19 18:41
 */
@Data
@ApiModel
public class GetEquityListVO implements Serializable {

    private static final long serialVersionUID = -6781779476604755789L;

    @ApiModelProperty(value = "权益id")
    private Long equityId;

    @ApiModelProperty(value = "权益名称")
    private String equityName;

    @ApiModelProperty(value = "权益分组(1xx权益,2xx权益,3xx权益,4xx权益)")
    private Integer equityClassification;

    @ApiModelProperty(value = "权益说明")
    private String equityExplain;

    @ApiModelProperty(value = "权益正式图标")
    private String equityActiveIcon;

    @ApiModelProperty(value = "权益下的规则id集合")
    private List<Long> equityRuleIds;
}

mybatis的xml代码

<resultMap id="GetEquityListResultMap" type="com.xxxx.admin.model.vo.equity.GetEquityListVO">
        <id column="equityId" property="equityId" />
        <result column="equityName" property="equityName" />
        <result column="equityClassification" property="equityClassification" />
        <result column="equityActiveIcon" property="equityActiveIcon" />
        <result column="equityExplain" property="equityExplain" />
        <collection column="equityId" property="equityRuleIds" ofType="java.lang.Long" select="getEquityRuleIds"/>
    </resultMap>
    <select id="getEquityList" parameterType="java.lang.Integer" resultMap="GetEquityListResultMap">
        select
            equity_id as equityId,
            equity_name as equityName,
            equity_classification as equityClassification,
            equity_explain as equityExplain,
            equity_active_icon as equityActiveIcon
          from equity_config
          where flag_del = 0 and state = 0 and equity_classification = #{equityClassification}
            order by sort desc
    </select>
    <select id="getEquityRuleIds" parameterType="java.lang.Long" resultType="java.lang.Long">
        select equity_rule_id from equity_config_rule where flag_del = 0 and state = 0 and equity_id = #{equityId}
    </select>

说明:

getEquityList :查询权益集合sql
getEquityRuleIds : 查询权益规则集合的sql
GetEquityListResultMap : 权益集合的resultMap结果映射

所以,核心就是这一行

<collection column="equityId" property="equityRuleIds" ofType="java.lang.Long" select="getEquityRuleIds"/>

更多示例和教程,大家可以参考mybatis官方中文文档进行学习
https://mybatis.org/mybatis-3/zh/sqlmap-xml.html#Result_Maps

如果该文章有帮助到您,就留言点个赞吧!您的支持与肯定是我持续更新最大的动力。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MyBatis是一个开源的持久层框架,它可以帮助我们简化JavaEE应用程序中的数据库访问操作。在MyBatis中,一对多嵌套查询是指在查询结果中包含了一个对象和该对象所关联的多个子对象。 在JavaEE中使用MyBatis进行一对多嵌套查询的步骤如下: 1. 定义实体类:首先需要定义两个实体类,一个是主对象的实体类,另一个是子对象的实体类。主对象实体类中需要包含一个子对象的集合属性。 2. 编写Mapper接口:创建一个Mapper接口,其中定义了查询方法,使用@Results和@Result注解来映射查询结果到实体类中。 3. 编写Mapper XML文件:在Mapper XML文件中编写SQL语句,使用嵌套查询的方式来获取主对象和子对象的数据,并通过resultMap将查询结果映射到实体类中。 4. 调用Mapper接口:在Java代码中调用Mapper接口的方法来执行查询操作,获取一对多嵌套查询的结果。 下面是一个示例代码,演示了如何使用MyBatis进行一对多嵌套查询: 1. 定义主对象实体类: ```java public class Order { private int id; private String orderNo; private List<OrderItem> orderItems; // 省略getter和setter方法 } ``` 2. 定义子对象实体类: ```java public class OrderItem { private int id; private String productName; // 省略getter和setter方法 } ``` 3. 编写Mapper接口: ```java public interface OrderMapper { @Results(id = "orderResultMap", value = { @Result(property = "id", column = "id"), @Result(property = "orderNo", column = "order_no"), @Result(property = "orderItems", column = "id", javaType = List.class, many = @Many(select = "com.example.mapper.OrderItemMapper.findByOrderId")) }) @Select("SELECT * FROM orders WHERE id = #{id}") Order findById(int id); } ``` 4. 编写Mapper XML文件: ```xml <mapper namespace="com.example.mapper.OrderMapper"> <resultMap id="orderResultMap" type="com.example.entity.Order"> <id property="id" column="id"/> <result property="orderNo" column="order_no"/> <collection property="orderItems" ofType="com.example.entity.OrderItem"> <id property="id" column="id"/> <result property="productName" column="product_name"/> </collection> </resultMap> <select id="findById" resultMap="orderResultMap"> SELECT * FROM orders WHERE id = #{id} </select> </mapper> ``` 5. 调用Mapper接口: ```java public class Main { public static void main(String[] args) { SqlSessionFactory sqlSessionFactory = ...; // 初始化SqlSessionFactory try (SqlSession sqlSession = sqlSessionFactory.openSession()) { OrderMapper orderMapper = sqlSession.getMapper(OrderMapper.class); Order order = orderMapper.findById(1); System.out.println("订单号:" + order.getOrderNo()); System.out.println("订单项:"); for (OrderItem orderItem : order.getOrderItems()) { System.out.println("商品名称:" + orderItem.getProductName()); } } } } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值