Mybatis 一对多查询返回结果只有一条:解决思路

使用的ssm框架:

首先上xml配置文件信息:

</resultMap>

<resultMap id="userMap" type="User">
	<id column="user_id" property="id"/>
	<result column="user_name" property="name"/>
	<result column="user_nickname" property="nickname"/>
	<result column="user_username" property="username"/>
	<result column="user_password" property="password"/>
	<result column="user_telphone1" property="telphone1"/>
	<result column="user_telphone2" property="telphone2"/>
	<result column="user_address" property="address"/>
	<result column="user_email" property="email"/>
</resultMap>

<resultMap id="materialInfoMap" type="MaterialInfo">
	<id column="materialInfo_id" property="id"/>
	<result column="materialInfo_name" property="name"/>
	<result column="materialInfo_number" property="number"/>
	<result column="materialInfo_company" property="company"/>
</resultMap>
<select id="loadListByMap " resultMap="materialMap">
	SELECT
		* 
	FROM
		t_material m
		LEFT JOIN t_materialinfo mi 
			ON m.material_id = mi.material_id
		LEFT JOIN t_user u 
			ON u.user_id = m.user_id 
		LEFT JOIN t_material_region mr 
			ON mr.material_id = m.material_id
	WHERE 1=1
		<choose>
			<when test="mId != null">
				AND	m.material_id = #{mId}
			</when>
			<when test="rId != null">
				AND	mr.region_id = #{rId}
			</when>
			<when test="tRId != null">
				AND	mr.tregion_id = #{tRId}
			</when>
			<when test="uId != null">
				AND m.user_id = #{uId}
			</when>
		</choose>
			<if test="state != null">
				AND m.material_state = #{state}
			</if>
</select>

写的有点多简单介绍一下整体结构
Material -----对应多张MaterialInfo表
Material ----对应一张User表
使用select语句,采用的是动态sql的方法

问题日志显示:
MaterialDao.loadListByMap - <== Row: 1, 1, 1, 2020-11-12 19:10:40, 1, 数学书, 10, 本

在数据库中应该是有三条数据但是在这里只有一条:
其问题是
![在这里插入图片描述](https://img-blog.csdnimg.cn/20201119230144472.png#pic_center
在对列名和属性名的配置上出现了不匹配,由于我的mapper映射文件很多所有复制结构的时候有了疏忽,导致没有正确匹配。

在查询时,先使用中的语句,而sql是没有错误的所以在日志中并没有报错,而在返回结果集是需要映射,这时候就出现了不匹配的问题,会导致结果集覆盖的情况。

此外我还在网上找到了一些其它导致一对多返回结果只有一条的原因我也列举一下:
1.两张表中的id字段是一样的,这样也会导致sql结果集的覆盖
在这里插入图片描述

在这里插入图片描述
如果这两处的值一样的话也会导致结果集覆盖,解决方法就是使用别名。
2.就是我最初说的column 和 property 不匹配的问题了。

在这里我说下自己的经验,如果花了很多时间没有解决sql的问题,可以新建一个项目专门搭建和运行mybatis框架
在这里插入图片描述
这样可以大大暴露代码中的问题,因为在SSM中有一些错误是不好判断的,单独运行一个框架,加上使用log4j会减少时间上的浪费,最重要的是缓解心态上的压力,整上好几个小时会很难受。

同时我给一下log4j关于sql的配置(个人认为很全):
#show sql
log4j.logger.java.sql.ResultSet=INFO
log4j.logger.org.apache=INFO
log4j.logger.java.sql.Connection=DEBUG
log4j.logger.java.sql.Statement=DEBUG
log4j.logger.java.sql.PreparedStatement=DEBUG
log4j.logger.com.rjxy.aowu.dao=TRACE

如果有问题的请各位指出,我会尽快修改。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值