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, 本
在数据库中应该是有三条数据但是在这里只有一条:
其问题是
在对列名和属性名的配置上出现了不匹配,由于我的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
如果有问题的请各位指出,我会尽快修改。
上一篇: 有哪些可以提升编程技能的好书值得推荐?