resultMap中的collection集合出现只能读取一条数据的解决方法
查询数据时只能获得collection集合中的的一条数据,相关情况如下:
结果集resultMap:
<resultMap id="ManagerRolesAcls" type="com.meikai.shop.entity.TSystemManager">
<id column="ID" jdbcType="BIGINT" property="id" />
<result column="create_date" jdbcType="TIMESTAMP" property="createDate" />
<result column="update_date" jdbcType="TIMESTAMP" property="updateDate" />
<result column="manager_name" jdbcType="VARCHAR" property="managerName" />
<result column="nickname" jdbcType="VARCHAR" property="nickname" />
<result column="password" jdbcType="VARCHAR" property="password" />
<result column="avatar" jdbcType="VARCHAR" property="avatar" />
<result column="is_enable" jdbcType="INTEGER" property="isEnable" />
<result column="is_locked" jdbcType="INTEGER" property="isLocked" />
<result column="try_num" jdbcType="INTEGER" property="tryNum" />
<result column="locked_date" jdbcType="TIMESTAMP" property="lockedDate" />
<result column="is_forver" jdbcType="INTEGER" property="isForver" />
<result column="login_time" jdbcType="TIMESTAMP" property="loginTime" />
<result column="login_ip" jdbcType="VARCHAR" property="loginIp" />
<result column="email" jdbcType="VARCHAR" property="email" />
<result column="active_code" jdbcType="VARCHAR" property="activeCode" />
<!-- 拥有角色集合 -->
<collection property="roles" ofType="com.meikai.shop.entity.TSystemRole" javaType="java.util.ArrayList">
<id column="ID" jdbcType="BIGINT" property="id" />
<result column="role_name" jdbcType="VARCHAR" property="roleName" />
<!-- 拥有资源集合 -->
<collection property="acls" ofType="com.meikai.shop.entity.TSystemAcl" javaType="java.util.ArrayList">
<id column="ID" jdbcType="BIGINT" property="id" />
<result column="permission" jdbcType="VARCHAR" property="permission" />
</collection>
</collection>
</resultMap>
5表关联查询:
<!-- 根据用户ID获得用户及其角色和资源 -->
<select id="getRolesAndAclsByID" parameterType="Long" resultMap="ManagerRolesAcls">
SELECT m.*,r.ID,r.role_name,a.ID,a.permission
FROM t_system_manager m
LEFT JOIN
t_system_manager_role mr ON m.ID=mr.manager_id
LEFT JOIN t_system_role r ON mr.`role_id`=r.`ID`
LEFT JOIN t_system_role_acl ra ON r.`ID`=ra.`role_id`
LEFT JOIN t_system_acl a ON a.`ID`=ra.`acl_id`
WHERE m.ID=#{id,jdbcType=BIGINT};
</select>
根据ID获得管理员:
@RequestMapping(value= {"view"},method = { RequestMethod.GET })
@ResponseBody
public TSystemManager view(HttpServletRequest request,Long id) {
TSystemManager viewManager = managerService.getRolesAndAclsByID(id);
for(TSystemRole role : viewManager.getRoles()) {
System.out.append("拥有的角色是:"+role.getRoleName());
for(TSystemAcl acl : role.getAcls()) {
System.out.append("拥有的资源是:"+acl.getPermission());
}
}
return viewManager;
}
在mysql通过上述5表查询语句能查询多条关于角色和资源的记录,但是通过mybatis查询获得的只有单条角色和资源的数据。
在sqlyog的查询结果:
通过mybatis获得的结果:
排查许久发现原因是:
1、主表的id字段和从表的id字段一样;
2、collection集合中包含<id column="ID" jdbcType="BIGINT" property="id" />;
如果同时存在上面两种情况,就只能获得collection的一条数据。
解决方法:
去掉collection的<id column="ID" jdbcType="BIGINT" property="id" />后,才能查询出全部数据。
resultMap中的collection集合出现只能读取一条数据的解决方法的更多相关文章
- mui--使用mui中的图文表格组件时出现一条横线的解决方法
最近做的微信公众号点击链接跳转到H5页面,该H5页面使用mui做的,遇到的商品列表页出现一个横线的问题, 这个是修改前的图片 解决方法: <style type="text/css&q ...
- Mybatis一对多或多对多只能查出一条数据解决策略
原文:https://blog.csdn.net/ren814/article/details/81742242 <resultMap id="menuModelMap" t ...
- 转: 从Mysql某一表中随机读取n条数据的SQL查询语句
若要在i ≤ R ≤ j 这个范围得到一个随机整数R ,需要用到表达式 FLOOR(i + RAND() * (j – i + 1)).例如, 若要在7 到 12 的范围(包括7和12)内得到一个随机 ...
- 从Mysql某一表中随机读取n条数据的SQL查询语句
若要在i ≤ R ≤ j 这个范围得到一个随机整数R ,需要用到表达式 FLOOR(i + RAND() * (j – i + 1)).例如, 若要在7 到 12 的范围(包括7和12)内得到一个随机 ...
- java读取PHP接口数据的实现方法(四)
PHP文件: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 3 ...
- jquery easyui datagrid 多选只能获取一条数据
DataGrid属性: singleSelect ------如果为true,则只允许选择一行: idField ------- 指明哪一个字段是标识字段: 方法: 一:getSelections-- ...
- ckeditor出现错误“从客户端(***)中检测到有潜在危险的 Request.Form值”的解决方法
ckeditor出现错误“从客户端(***)中检测到有潜在危险的 Request.Form值”的解决方法 页面中使用ckeditor,提交文章时总是出错,“从客户端(TextBox1="&l ...
- 从客户端中检测到有潜在危险的Request.Form值的解决方法
描述:从客户端中检测到有潜在危险的Request.Form值的解决方法asp.net 2.0 通常解决办法将.aspx文件中的page项添加ValidateRequest="false&qu ...
- 在VMware 虚拟机中配置 windows2003系统的NLB负载均衡;0x800706D5错误的解决方法;没有接口可用于安装新的群集
首先在VM里面 我装了3个2003的系统, 分别为 webservice01 ,webservice 02 , 以及 webview 这3台. 前面两台用于配置负载均衡,后面的webview就是 ...
随机推荐
- 使用highmaps制作中国地图
Highmaps 所需文件 http://code.highcharts.com/maps/highmaps.js(地图渲染的核心文件 必须引用)http://code.highcharts.com/ ...
- 批量修改文件格式到UTF-8
系统环境: Unbuntu14.10 目标: 多个文件夹加下的大量.java文件,需要由ASCII,转为UTF-8编码格式,文件嵌套较深. 解决方案: 执行Console中,目标目录下执行一下命令: ...
- BZOJ3769:BST again(记忆化搜索DP)
Description 求有多少棵大小为n的深度为h的二叉树.(树根深度为0:左右子树有别:答案对1000000007取模) Input 第一行一个整数T,表示数据组数. 以下T行,每行2个整数n和h ...
- 【bzoj2154】Crash的数字表格 莫比乌斯反演
题目描述 今天的数学课上,Crash小朋友学习了最小公倍数(Least Common Multiple).对于两个正整数a和b,LCM(a, b)表示能同时被a和b整除的最小正整数.例如,LCM(6, ...
- hdu_1009 贪心
FatMouse' Trade Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)T ...
- Nginx Web服务器配置
Nginx是一个轻量级高性能的web服务器,它是为快速响应大量静态文件请求和高效利用系统资源而设计的.与apache使用面向进程或线程的方式处理请求不同,nginx使用异步事件驱动模型在连接高并发的情 ...
- Semtech 的 137-1050 MHz 超低功耗长距离收发器(SX1276 Long Range Transceiver)
SX1276 收发器采用 LoRa? 长距离调制解调器,可实现超长距离扩频通信和高抗干扰能力,并将电流消耗降至最低.凭借 Semtech 专利的 LoRa 调制技术,SX1276 使用低成本晶体和物料 ...
- 【Linuc-CentOS 】通过yum安装 指定版本的nodejs
原 [Linuc-CentOS ]通过yum安装 指定版本的nodejs 2018年06月21日 06:56:32 黑夜的风 阅读数:884 版权声明:本文为博主原创文章,未经博主允许不得转载. ...
- PAT——1031. 查验身份证
一个合法的身份证号码由17位地区.日期编号和顺序编号加1位校验码组成.校验码的计算规则如下: 首先对前17位数字加权求和,权重分配为:{7,9,10,5,8,4,2,1,6,3,7,9,10,5,8, ...
- 阅读 CloudDPI:Cloud+DPI+Reversible Sketch
CloudDPI: Cloud-Based Privacy-Preserving Deep Packet Inspection via Reversible Sketch 与sketch的结合点:将修 ...