繁体   English   中英

Spring 引导 JSON 序列化与父表

[英]Spring Boot JSON serialization with parent table

早上好,我正在尝试从 spring 引导接收 ajax 调用 JSON 与一系列包含子表和父亲的字段。

我已经遇到了无限递归等问题,并用@JsonManagedReference 和@JsonBackReference 修复了它。 现在发生了什么? 我至少需要获取父表中的数据以获取一个值,但是当我们在 Ajax 中得到答案时,它不会出现。

我怎样才能在不陷入无限递归的情况下获取该数据?

这些将是表格,我删除了字段,使其不会很长。

@Entity
@Table(name="actividad_servicio")
public class Actividad_Servicio implements Serializable {

    @JsonBackReference
    @ManyToOne
    @JoinColumn(foreignKey = @ForeignKey(name = "fk_actividad_servicio_tipo_actividad_servicio_id"), name="tipo_actividad_servicio_id", nullable = false, columnDefinition = "int")
    private Tipo_Actividad_Servicio tipo_actividad_servicio;
    
    @JsonBackReference
    @ManyToOne
    @JoinColumn(foreignKey = @ForeignKey(name = "fk_actividad_servicio_empleado_id"), name="empleado_id",columnDefinition = "int")
    private Empleado empleado;

    @JsonManagedReference
    @OneToMany(mappedBy = "actividad_servicio", cascade=CascadeType.ALL, orphanRemoval = true)
    private Set<Actividad_Servicio_Alumno> actividad_servicio_alumno = new HashSet<Actividad_Servicio_Alumno>();
    
    @JsonManagedReference
    @OneToOne(mappedBy = "actividad_servicio", cascade=CascadeType.ALL, orphanRemoval = true)
    private Horario_Actividad_Servicio horario_actividad_servicio = new Horario_Actividad_Servicio();

    @JsonManagedReference
    @OneToMany(mappedBy = "actividad_servicio", cascade=CascadeType.ALL, orphanRemoval = true)
    private Set<Factura> factura = new HashSet<Factura>();

}

@Entity
@Table(name="horario_actividad_servicio")
public class Horario_Actividad_Servicio implements Serializable {

    @JsonBackReference
    @OneToOne(cascade = CascadeType.ALL)
    @JoinColumn(foreignKey = @ForeignKey(name = "fk_horario_actividad_servicio_actividad_servicio_id"), name="actividad_servicio_id", referencedColumnName = "id", columnDefinition = "int")
    private Actividad_Servicio actividad_servicio;

}

@Entity
@Table(name="tipo_actividad_servicio")
public class Tipo_Actividad_Servicio implements Serializable {

    @JsonManagedReference
    @OneToMany(mappedBy = "tipo_actividad_servicio", cascade = CascadeType.ALL, orphanRemoval = true)
    private Set<Actividad_Servicio> actividad_servicio = new HashSet<Actividad_Servicio>();

}

在将响应返回给 Ajax 之前,我查看了 service_activity object 的内容,它显示了 service_activity_type 及其属性。

@RestController
@RequestMapping("/actividades/rest")
public class ActividadRestController {

    @Autowired
    private Actividad_ServicioService actividad_servicioService;

    @GetMapping
    public Response findOne(@RequestParam int id, Model model) {

        Response response = new Response();

        try {
            Actividad_Servicio actividad_servicio = actividad_servicioService.findById(id);

            response = new Response("Done", actividad_servicio);

        } catch (Exception e) {

            response = new Response("Error", Constants.Error);
            e.printStackTrace();

        }

        return response;

    }

}

但是当它回到 Ajax 时,我检查了我得到的内容是这样的:

Success:  - {…}
​            - data: {…}
​​              +  actividad_servicio_alumno: Array []
​​              +  factura: Array []
​​              +  horario_actividad_servicio: Object { id: 10, l: null, hora_inicio_l: "", …}
​​                 <prototype>: Object { … }
​              status: "Done"
​              <prototype>: Object { … }

但是 service_activity_type 并没有出现以获取某个字段的值。 我知道这与无限递归的问题相冲突,但我想有些事情发生在我身上,我留下了一个注释,以便我可以获得那些父值。

非常感谢您的帮助。

首先,不要直接使用实体 class 作为响应,当你想部分忽略时会产生很多问题。

为响应创建 DTO class 以仅序列化您要发送的那些字段。 Map 实体数据响应使用任何 model 映射工具,如 Modelmapper 或 MapStruct。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM