mybatis 使用collection标签实现一对多查询(多分页使用)

在使用**ListPage分页工具类进行分页操作时,如果使用一对多查询,会造成查询出来每一页数据数量不等于实际规定的每一个数据数量。原因在于,一对多查询的结果是包含了与子表链接的数据,例如在查询10个订单(order_header)数据时,假如有两个订单均包含2条订单条目(order_detail)数据,那么最终查询的10条数据只有8条order_header表的数据。



通常,我们为了解决这种问题,首先会先获取到10条order_header数据,然后在遍历订单数据分别获取每一条订单数据的订单条目数据,这样会浪费数据库的执行时间,下面使用collection进行查询的方法,可以避开普通collection查询造成的问题,也能达到其效果。


Mapper:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="OrderHeaderMapper">
    <resultMap id="OrderView_M" type="OrderView_M">
        <id column="order_id" property="orderID" jdbcType="INTEGER"/>
        <result column="order_number" property="orderNumber" jdbcType="VARCHAR"/>
        <result column="total_amount" property="totalAmount" jdbcType="DECIMAL"/>
	<result column="pay_status_id" property="payStatusID"/>
        <result column="order_status_id" property="orderStatusID"/>
        <collection property="orderDetail" column="order_id" ofType="OrderDetailView_M" javaType="ArrayList" select="getOrderDetailByOrderID">

        </collection>
    </resultMap>

	<resultMap id="OrderDetailView_M" type="OrderDetailView_M">
		<id column="order_detail_id" property="orderDetailID" jdbcType="INTEGER"/>
		<result column="product_name" property="productName" jdbcType="VARCHAR"/>
		<result column="photo_path" property="photoPath" jdbcType="VARCHAR"/>
	</resultMap>
	<!-- page为一个自定义分页类,其中包括一个pd的map -->
	<select id="getOrderByCustomerListPage" parameterType="page" resultMap="OrderView_M">
        	SELECT
			oh.order_id,
			oh.order_number,
			oh.total_amount,
			oh.pay_status_id,
            		oh.order_status_id
		FROM
			order_header oh
		WHERE oh.pay_status_id = #{pd.orderStatusID}
		ORDER BY oh.order_date DESC
    	</select>

	<select id="getOrderDetailByOrderID" parameterType="java.lang.Integer" resultMap="OrderDetailView_M">
		SELECT
		od.order_detail_id,
		od.product_name,
		od.photo_path,
		od.order_id
		FROM
		order_detail od
		LEFT JOIN product p ON p.product_id = od.product_id
		WHERE od.order_id = #{order_id}
		ORDER BY p.sku
	</select>
</mapper>



public class OrderView_M {
    private Integer orderID;
    private String orderNumber;
    private BigDecimal totalAmount;
    private Integer payStatusID;
    private Integer orderStatusID;
    private List<OrderDetailView_M> orderDetail;

    public Integer getPayStatusID() {
        return payStatusID;
    }

    public Integer getOrderStatusID() {
        return orderStatusID;
    }

    public void setOrderStatusID(Integer orderStatusID) {
        this.orderStatusID = orderStatusID;
    }

    public void setPayStatusID(Integer payStatusID) {
        this.payStatusID = payStatusID;
    }

    public Integer getOrderID() {
        return orderID;
    }

    public void setOrderID(Integer orderID) {
        this.orderID = orderID;
    }

    public String getOrderNumber() {
        return orderNumber;
    }

    public void setOrderNumber(String orderNumber) {
        this.orderNumber = orderNumber;
    }

    public BigDecimal getTotalAmount() {
        return totalAmount;
    }

    public void setTotalAmount(BigDecimal totalAmount) {
        this.totalAmount = totalAmount;
    }

    public List<OrderDetailView_M> getOrderDetail() {
        return orderDetail;
    }

    public void setOrderDetail(List<OrderDetailView_M> orderDetail) {
        this.orderDetail = orderDetail;
    }
}



public class OrderDetailView_M {
    private Integer orderDetailID;
    private String productName;
    private String photoPath;

    public String getProductName() {
        return productName;
    }

    public void setProductName(String productName) {
        this.productName = productName;
    }

    public String getPhotoPath() {
        return photoPath;
    }

    public void setPhotoPath(String photoPath) {
        this.photoPath = photoPath;
    }

    public Integer getOrderDetailID() {
        return orderDetailID;
    }

    public void setOrderDetailID(Integer orderDetailID) {
        this.orderDetailID = orderDetailID;
    }
}


### 回答1: Mybatis查询一对多分页可以通过两种方式实现。 第一种方式是使用Mybatis的内置分页插件PageHelper。通过在需要分页查询的方法前加上PageHelper.startPage(pageNum, pageSize)代码,然后执行查询语句,就可以在查询结果中获取到分页后的数据。同时,可以使用PageInfo对查询结果进行封装,获取到分页的相关信息。 第二种方式是手动实现分页功能。可以通过编写SQL语句,使用LIMIT和OFFSET关键字来实现分页查询。根据页面传来的页码和每页显示数量,计算出需要跳过的记录数量,然后在查询语句中使用LIMIT限制查询结果的数量,OFFSET指定跳过的记录数量。最后,将查询结果返回即可。 无论使用哪种方式,一对多分页查询都需要考虑到关联表的关系。在设置分页查询条件时,需要注意关联表之间的查询条件,以及在查询结果中如何处理关联表的数据。 总结起来,Mybatis查询一对多分页可以通过使用内置分页插件PageHelper或者手动编写SQL语句实现。在设置分页查询条件时,要考虑关联表的关系,以及在查询结果中如何处理关联表的数据。 ### 回答2: MyBatis是一个在Java中使用的持久层框架,它可以用来简化数据库查询和操作的编码工作。在MyBatis中进行一对多查询分页,需要通过配置文件和SQL语句来实现。 首先,在配置文件中配置数据库连接信息和映射文件等。然后,在映射文件中编写需要的SQL语句。对于一对多查询,可以使用嵌套查询或者关联查询使用嵌套查询的方式,可以先查询主表的信息,然后在嵌套查询查询与主表关联的从表的信息。在查询结束后,可以通过PageHelper插件来实现分页功能。 使用关联查询的方式,可以使用SQL的连接语句来一次性查询主表和从表的信息。在查询结束后,同样可以通过PageHelper插件来实现分页功能。 无论使用哪种方式,最后都需要将查询结果封装为Java对象,并返回给调用方。 总结起来,要在MyBatis中进行一对多查询分页,首先需要配置数据库连接信息和映射文件。然后,根据需要的查询方式编写SQL语句。最后,使用PageHelper插件实现分页功能,将查询结果封装为Java对象返回。 ### 回答3: Mybatis是一种用于Java语言的持久层框架,可以方便地进行数据库操作。当需要查询一对多关系并进行分页时,可以通过以下步骤实现: 1. 首先,在数据库中建立相关的表,例如主表和从表,确保它们之间有一对多的关系。 2. 在Mybatis的XML配置文件中定义两个对应主表和从表的实体类和映射关系。在主表的映射文件中,使用collection标签引入从表的实体类和映射关系,并指明关联的字段。在从表的映射文件中,使用association标签引入主表的实体类和映射关系,并指明关联的字段。 3. 在主表的Mapper接口中定义一对多查询的方法,使用@Results和@Result注解进行映射配置。在@Results注解中使用@Result注解指定查询结果的字段名和对应的实体类属性名。在@Result注解中使用@Collection注解指定从表的映射配置。 4. 在Mapper接口的XML配置文件中实现一对多查询的SQL语句,并使用分页相关的SQL语句进行结果分页。可以使用limit和offset关键字实现分页查询。 5. 在DAO层或Service层调用Mapper接口中定义的一对多查询方法,并传入分页参数,获取查询结果。 这样就可以实现Mybatis一对多查询分页功能。通过配置实体类和映射关系,定义查询方法,并使用分页相关的SQL语句,可以方便地实现一对多关系数据的分页查询Mybatis的灵活性和便捷性使得开发人员可以很方便地操作数据库,减少了大量重复的编码工作,提高了开发效率。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值