mysql一对多关联查询分页错误问题的解决方法

2023年 4月 28日 48.9k 0

xml问价中查询数据中包含list,需要使用collection resultMap type="com.XXX.XXXX" id column="o_id" jdbcType="BIGINT" property="id" / result column="o_user_id" jdbcType="BIGINT" property="userId" / .... collection property

xml问价中查询数据中包含list,需要使用collection

<resultMap type="com.XXX.XXXX">
<id column="o_id" jdbcType="BIGINT" property="id" />
<result column="o_user_id" jdbcType="BIGINT" property="userId" />
....
<collection property="orderProductList" ofType="com.XXXXXX.XXXXX">
<id column="p_id" jdbcType="BIGINT" property="id" />
<result column="p_order_id" jdbcType="BIGINT" property="orderId" />
....
</collection>
</resultMap>

这样的查询系统封装的通用分页查询是不对的,所以需要自己sql中加入分页解决

<select resultMap="OrderListMap">
SELECT
you.nick_name,
yo.id o_id,
yo.user_id o_user_id
FROM
(
SELECT * FROM
youpin_order
WHERE
1 = 1
<if test="status != null">
and `status` = #{status}
</if>
<if test="page != null and limit != null">
LIMIT #{page},
#{limit}
</if>
) yo
LEFT JOIN XXX yop ON yo.id = yop.order_id
LEFT JOIN XXXX you ON yo.user_id = you.id
</select>

传入参数的时候需要计算

(offset - 1) * limit, limit

总结

以上所述是小编给大家介绍的mysql一对多关联查询分页错误问题的解决方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对每日运维网站的支持!

相关文章

Oracle如何使用授予和撤销权限的语法和示例
Awesome Project: 探索 MatrixOrigin 云原生分布式数据库
下载丨66页PDF,云和恩墨技术通讯(2024年7月刊)
社区版oceanbase安装
Oracle 导出CSV工具-sqluldr2
ETL数据集成丨快速将MySQL数据迁移至Doris数据库

发布评论