利用mybatis对collection进行嵌套时出现报错如何解决?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。
在赤壁等地区,都构建了全面的区域性战略布局,加强发展的系统性、市场前瞻性、产品创新能力,以专注、极致的服务理念,为客户提供做网站、成都网站设计 网站设计制作定制网站,公司网站建设,企业网站建设,高端网站设计,营销型网站建设,成都外贸网站制作,赤壁网站建设费用合理。p.Id, p.Name, p.SurName, c.Id as c_Id, c.ParentId as c_ParentId, c.Name as c_Name, c.SurName as c_Surname, c.Age as c_Age, t.Id as t_Id, t.Name as t_Name, t.Color as t_Color
表面来看没有任何问题 实际 查询的child对象中的toys一直是空
类关系介绍:
Parent类有属性ArrayList
Child类有属性ArrayList
Toy是一个普通的类
原因在于:
columnPrefix配置的是t_实际mybatis处理后是 c_t_
解决办法:
只需要修改 sql 修改前缀为 c_t_ 即可
t.Id as c_t_Id, t.Name as c_t_Name, t.Color as c_t_Color
补充知识:mybatis 嵌套的结果集不能被安全的转为自定义ResultHandler 的解决办法
org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.executor.ExecutorException: Mapped Statements with nested result mappings cannot be safely used with a custom ResultHandler. Use safeResultHandlerEnabled=false setting to bypass this check.
问题描述
session.select("dao.ArticleMapper.selectAll", null, new RowBounds(1, 2),resultHandler);
会报不安全, 查询Configuration 源码发现里面有一个常量是
public Configuration() { this.safeRowBoundsEnabled = false; this.safeResultHandlerEnabled = true;//意思是不允许自定义ResultHand 处理器, this.mapUnderscoreToCamelCase = false; this.aggressiveLazyLoading = true;
解决办法
public static SqlSession getsqlSession(){ SqlSession session = sqlSessionFactory.openSession(ExecutorType.REUSE); Configuration configuration = session.getConfiguration(); //反射得到configuration ,然后 configuration.setSafeResultHandlerEnabled(false); // 设置为false return session; }
看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注创新互联行业资讯频道,感谢您对创新互联网站建设公司,的支持。