Spring Data JPA:插入为null的相关实体值

时间:2015-08-10 19:18:20

标签: database spring jpa crud

我对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列为空。

这些实体是否未正确映射?什么想法可能是错的?

非常感谢帮助!

1 个答案:

答案 0 :(得分:0)

是的,似乎analyzerepo.findOne没有返回实例 - 感谢Chris。

所以,这很有效:

Analysis a = analysisrepo.findOne(analysisid);
repository.save(new Request(pharmacometrician,programmer,project,study,folderpath,a));

不知道为什么这是必要的,但至少它现在正在工作。

谢谢!