gpt4 book ai didi

java - 如何使用 JPA 关系实体创建 RestAPI

转载 作者:行者123 更新时间:2023-12-02 10:46:30 26 4
gpt4 key购买 nike

我有一个问题。当我有其他实体时,我不知道如何创建 API。我与 Postman 合作,当我请求查看数据库中的所有项目时,我也想接收这些实体。

例如,这是我的实体:

@Entity
@Table(name = "project")
public class Project {

@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "proj_id")
private int projectId;

@Column(name = "project_name")
private String projectName;

@Column(name = "dg_number")
private int dgNumber;

@ManyToMany
@JoinTable(name = "project_gate_relation", joinColumns = @JoinColumn(name = "proj_id"), inverseJoinColumns = @JoinColumn(name = "gate_id"))
@JsonBackReference
private List<Gate> gates;

@ManyToMany
@JoinTable(name = "project_threshold_relation", joinColumns = @JoinColumn(name = "proj_id"), inverseJoinColumns = @JoinColumn(name = "thresholdgates_id"))
@JsonBackReference
private List<Threshold> thresholds;

这是门实体

@Entity
@Table(name = "gate")
public class Gate {

@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "gate_id")
private int gateId;

@Column(name = "gate_type")
private String gateType;

@Column(name = "gate_value")
private float value;

阈值实体

@Entity
@Table(name = "threshold")
public class Threshold {

@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "threshold_id")
private int thresholdId;

@Column(name = "threshold_value")
private int thresholdValue;

@Column(name = "threshold_type")
private String thresholdType;

Controller

@RestController
@RequestMapping(ProjectController.PROJECT_URL)
public class ProjectController {

public static final String PROJECT_URL = "/cidashboard/projects";

@Autowired
private final ProjectService projectService;

public ProjectController(ProjectService projectService) {
this.projectService = projectService;
}

@GetMapping
public List<Project> getAllProjects(){
return projectService.findAllProjects();
}

@GetMapping("/{id}")
public Project getProjectById(@PathVariable int id) {
return projectService.findProjectById(id);
}

@PostMapping
// @Consumes(MediaType.APPLICATION_JSON_VALUE)
public Project saveProject(@RequestBody Project newProj) {
return projectService.saveProject(newProj);
}
}

当我在 Postman 中执行 Get 请求时,我收到以下输出:

 {
"projectId": 1,
"projectName": "jenkins",
"dgnumber": 1
},

我也希望收到有关门和阈值的信息。我不明白如何更准确地做这件事。

最佳答案

JPA 中默认不加载相关实体。您必须在@ManyToMany关系中定义fetch = FetchType.EAGER

@ManyToMany(fetch = FetchType.EAGER)
@JoinTable(name = "project_gate_relation", joinColumns = @JoinColumn(name = "proj_id"), inverseJoinColumns = @JoinColumn(name = "gate_id"))
@JsonBackReference
private List<Gate> gates;

@ManyToMany(fetch = FetchType.EAGER)
@JoinTable(name = "project_threshold_relation", joinColumns = @JoinColumn(name = "proj_id"), inverseJoinColumns = @JoinColumn(name = "thresholdgates_id"))
@JsonBackReference
private List<Threshold> thresholds;

关于java - 如何使用 JPA 关系实体创建 RestAPI,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52520910/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com