美文网首页
使用Mybatis时遇到的延迟加载造成返回异常的问题——Http

使用Mybatis时遇到的延迟加载造成返回异常的问题——Http

作者: 阿杰_96c5 | 来源:发表于2020-11-20 13:52 被阅读0次

    在使用Mybatis的过程中,使用了resultMap延迟加载。

    延迟加载:association联表查询的过程中,查询另外两个表的对象。而延迟加载是指只有在使用这两个对象的时候才会进行查询。

    问题的产生,在我这里,我是直接通过路由url直接查询 StudentDto_2 对象。延迟加载的对象为 TClass 和 Assistant.

     public  class  StudentDto_2  { 
        private  Integer stuId; 
        private  String stuNum;  //学生编号,unique
        private  String studentName; 
        private  Long birthDate;
        private  TClass tClass;
        private  Assistant assistant;
     }
    

    在序列化的过程中,会抛出以下异常。

    `2018-08-27  11:14:29.339 ERROR 34755  ---  [nio-8089-exec-1] o.a.c.c.C.[.[.[/].[dispatcherServlet]  :  Servlet.service()  for servlet [dispatcherServlet]  in context with path [] threw exception [Request processing failed; nested exception is org.springframework.http.converter.HttpMessageConversionException:  Type definition error:  [simple type,  class org.apache.ibatis.executor.loader.javassist.JavassistProxyFactory$EnhancedResultObjectProxyImpl]; nested exception is com.fasterxml.jackson.databind.exc.InvalidDefinitionException:  No serializer found for  class org.apache.ibatis.executor.loader.javassist.JavassistProxyFactory$EnhancedResultObjectProxyImpl  and  no properties discovered to create BeanSerializer  (to avoid exception, disable SerializationFeature.FAIL_ON_EMPTY_BEANS)  (through reference chain: com.zimo.mybaties.util.Result["data"]->com.zimo.mybaties.dto.StudentDto_2_$_jvstfe4_0["handler"])]  with root cause` 
    

    问题:Springmvc+mybatis,mybatis配置延迟加载时,json序列化异常

    我目前的解决办法是关闭延迟加载,关闭后一切正常。

    在SpringBoot中,默认使用Jackson来实现java对象到json格式的序列化与反序列化。Jackson的转化是通过ObjectMapper来实现的。SpringBoot内置了一个ObjectMapper。我们通过下面的配置来

    实现序列化Mybatis的延迟加载。

    import com.fasterxml.jackson.annotation.JsonInclude;
    import com.fasterxml.jackson.databind.ObjectMapper;
    import com.fasterxml.jackson.databind.SerializationFeature;
    import org.springframework.context.annotation.Configuration;
    @Configuration
    public class CustomerMapper extends ObjectMapper {
        public CustomerMapper() {
            this.setSerializationInclusion(JsonInclude.Include.NON_NULL);  //返回为null的值则去除,
            this.configure(SerializationFeature.FAIL_ON_EMPTY_BEANS,false);  //解决延迟加载的对象
        }
    }
    

    返回参数中了多了一个代理对象handle

    {
    "code": 200,
    "message": "获取学生信息",
    -"data": {
        "stuId": 22,
        "stuNum": "12310",
        "studentName": "天涯10",
        "birthDate": 777524356000,
        -"tClass": {
            "classId": 3,
            "classNum": "1921083145",
           "className": "数学"
            },
        -"assistant": {
           "assistantId": 1,
            "assistantNum": "1315151521",
            "name": "还在于是"
            },
        "handler": { }
        }
    }
    

    相关文章

      网友评论

          本文标题:使用Mybatis时遇到的延迟加载造成返回异常的问题——Http

          本文链接:https://www.haomeiwen.com/subject/jlpdiktx.html