我对Spring Data JPA很新,所以提前感谢任何帮助。
我有一个类/实体请求,它与另一个实体Analysis(ManyToOne)相关。我目前正在使用CrudRepository插入记录,但是当我插入新的Request并提供Analysis ID时,数据库中的AnalysisID列保留为null。有谁能解释为什么?以下是我的代码:
Request.java
@Entity
@Table(name="Requests")
@SequenceGenerator(name="req_seq",sequenceName="req_seq",allocationSize=1)
public class Request {
@Id
@GeneratedValue(strategy=GenerationType.SEQUENCE,generator="req_seq")
@Column(name="RequestID")
public long id;
public String pharmacometrician;
public String programmer;
public String project;
public String study;
@ManyToOne(fetch=FetchType.EAGER)
@JoinColumn(name="AnalysisID")
public Analysis analysisType;
@Column(name="WORKINGFOLDERPATH")
public String folder;
protected Request() {
}
public Request(String pharmacometrician,String programmer,String project, String study,String folderpath,Analysis analysis) {
Request request = new Request();
request.pharmacometrician = pharmacometrician;
request.programmer = programmer;
request.project = project;
request.study = study;
request.folder = folderpath;
request.analysisType = analysis;
}
Analysis.java
@Entity
@Table(name="ANALYSISTYPES")
@SequenceGenerator(name="analysisid_seq",sequenceName="analysisid_seq",allocationSize=1)
public class Analysis {
@Id
@GeneratedValue(strategy=GenerationType.SEQUENCE,generator="analysisid_seq")
@Column(name="AnalysisID")
public long id;
public String label;
public String description;
protected Analysis() {
}
public Analysis(String label,String description) {
this.label = label;
this.description = description;
}
RequestController.java
@RestController
@RequestMapping("request")
public class RequestController {
protected final Logger log = LoggerFactory.getLogger(getClass());
@Autowired
RequestRepository repository;
@Autowired
AnalysisRepository analysisrepo;
@RequestMapping("newrequest")
//@RequestMapping(method=RequestMethod.GET)
public void newRequest(@RequestParam(value="analysis",required=false) long analysisid,
@RequestParam(value="pm",required=false) String pharmacometrician,
@RequestParam(value="programer",required=false) String programmer,
@RequestParam(value="ta",required=false) long taid,
@RequestParam(value="purpose",required=false) long purposeid,
@RequestParam(value="project",required=false) String project,
@RequestParam(value="study",required=false) String study,
@RequestParam(value="folder",required=false) String folderpath) {
log.info("New request");
repository.save(new Request(pharmacometrician,programmer,project,study,folderpath,analysisrepo.findOne(analysisid)));
return;
//return repository.findOne(id);
}
}
我传入了分析ID,然后使用AnalysisRepository获取了一个Analysis对象,然后我用它来创建新的Request并使用RequestRepository保存到DB(扩展CrudRepository)。但是,当我查看数据库时,将填充所有字段,但analyzeid列为空。
这些实体是否未正确映射?什么想法可能是错的?
非常感谢帮助!
答案 0 :(得分:0)
是的,似乎analyzerepo.findOne没有返回实例 - 感谢Chris。
所以,这很有效:
Analysis a = analysisrepo.findOne(analysisid);
repository.save(new Request(pharmacometrician,programmer,project,study,folderpath,a));
不知道为什么这是必要的,但至少它现在正在工作。
谢谢!