1

我有一对多的关系,如以下两个类中所述

    @Entity
    @Table(name="version_mst")
    public class Version {

    private Long   id;
    private String versionName;
    private String releaseName;
    private Set<VersionReleaseComponents> versionReleaseComponents; 

    @Id
    @GeneratedValue
    @Column(name="id")
    public Long  getId() {
        return id;
    }
    public void setId(Long  id) {
        this.id = id;
    }

    @Column(name="versionName")
    public String getVersionName() {
        return versionName;
    }
    public void setVersionName(String versionName) {
        this.versionName = versionName;
    }

    @Column(name="releaseName")
    public String getReleaseName() {
        return releaseName;
    }
    public void setReleaseName(String releaseName) {
        this.releaseName = releaseName;
    }

    @OneToMany(mappedBy="version",cascade = { javax.persistence.CascadeType.ALL },fetch = FetchType.EAGER,targetEntity=VersionReleaseComponents.class)
    public Set<VersionReleaseComponents> getVersionReleaseComponents() {
        return versionReleaseComponents;
    }
    public void setVersionReleaseComponents(
            Set<VersionReleaseComponents> versionReleaseComponents) {
        this.versionReleaseComponents = versionReleaseComponents;
    }

      }       

一个版本有多个版本发布组件

     @Entity
     @Table(name="version_release_components")
     public class VersionReleaseComponents {

    private Long id;

    @Id
    @GeneratedValue
    @Column(name="id")
    public Long getId() {
        return id;
    }
    public void setId(Long id) {
        this.id = id;
    }

    @Column(name = "versionId")
    private Long versionId;
    public Long getVersionId() {
        return versionId;
    }
    public void setVersionId(Long versionId) {
        this.versionId = versionId;
    }
    private Version version;
    private String componentName;
    private String versionNumber;

    @ManyToOne(fetch = FetchType.EAGER)
    @JoinColumn(name="versionId", referencedColumnName="id", insertable = false, updatable = false)
    public Version getVersion() {
        return version;
    }
    public void setVersion(Version version) {
        this.version = version;
    }

    @Column(name="componentName")
    public String getComponentName() {
        return componentName;
    }
    public void setComponentName(String componentName) {
        this.componentName = componentName;
    }

    @Column(name="versionNumber")
    public String getVersionNumber() {
        return versionNumber;
    }
    public void setVersionNumber(String versionNumber) {
        this.versionNumber = versionNumber;
    }

        }     

当我尝试执行以下

        Version v = new Version();
        v.setReleaseName("RN1");
        v.setVersionName("VName1");

        VersionReleaseComponents vrc = new VersionReleaseComponents();
        vrc.setComponentName("cn1");
        vrc.setVersionNumber("VNum1");
        vrc.setVersion(v);

        v.getVersionReleaseComponents().add(vrc); // null pointer error on here
        session.saveOrUpdate(v);

获取集合时出现空指针异常。请指导我。

创建查询如下

      CREATE TABLE `version_mst` (
      `id` int(10) NOT NULL AUTO_INCREMENT,
      `versionName` varchar(20) NOT NULL,
      `releaseName` varchar(20) NOT NULL,
      `last_modified_timestamp` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
      PRIMARY KEY (`ID`),
      UNIQUE KEY `VERSION_MAPPING_MST_UNIQUE` (`versionName`,`releaseName`)
    ) ENGINE=InnoDB DEFAULT CHARSET=latin1;

    CREATE TABLE `version_release_components` (
      `id` int(10) NOT NULL AUTO_INCREMENT,
      `versionId` int(10) NOT NULL ,
      `componentName` varchar(20) NOT NULL,
      `versionNumber` varchar(20) NOT NULL,
      `last_modified_timestamp` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
      PRIMARY KEY (`ID`),
      CONSTRAINT `FK_VERSION` FOREIGN KEY (`versionId`) REFERENCES `version_mst` (`id`),
      UNIQUE KEY `VERSION_RELEASE_UNIQUE` (`componentName`,`versionNumber`)
    ) ENGINE=InnoDB   DEFAULT CHARSET=latin1;
4

5 回答 5

2

Version你还没有实例化:

private Set<VersionReleaseComponents> versionReleaseComponents; 

所以你正在添加VersionReleaseComponents一个未初始化的Set

要修复,请设置:

private Set<VersionReleaseComponents> versionReleaseComponents = new HashSet<VersionReleaseComponents>(); 

或任何Set你需要的

于 2012-12-13T15:00:16.600 回答
1

很可能是因为您尚未初始化Set变量。在构造函数或字段声明中对其进行初始化。

当我运行您的代码时,我遇到了同样的异常,然后在我将变量初始化为:

private Set<VersionReleaseComponents> versionReleaseComponents = new HashSet<>();
于 2019-09-18T03:29:34.640 回答
0

更改了以下内容:删除了 VersionReleaseComponents 中的声明

     @Column(name = "versionId")
    private Long versionId;
    public Long getVersionId() {
        return versionId;
    }
    public void setVersionId(Long versionId) {
        this.versionId = versionId;
    }

将 VersionReleaseComponents 声明更改为

 @JoinColumn(name="versionId")

和版本声明是

@OneToMany(mappedBy="id",cascade = { javax.persistence.CascadeType.ALL },fetch =  FetchType.LAZY)

上述更改奏效。由于某些其他原因,我已更改为 FetchType.LAZY,尽管它不是解决方案的一部分。

于 2012-12-14T06:42:21.890 回答
0

尝试更换

@ManyToOne(fetch = FetchType.EAGER)
@JoinColumn(name="versionId", referencedColumnName="id", insertable = false, updatable = false)
public Version getVersion() {
  return version;
}

为了这:

    @ManyToOne(fetch = FetchType.EAGER)
    @JoinColumn(name="versionReleaseComponents")
   public Version getVersion() {
      return version;
    }

并使用@user1393563 的推荐:

private Set<VersionReleaseComponents> versionReleaseComponents = new HashSet<VersionReleaseComponents>();

问候。

于 2012-12-13T15:29:46.160 回答
0

我认为您正在尝试向 Set 添加一个为 NULL 的项目。

尝试这个 :

    Version v = new Version();
    v.setReleaseName("RN1");
    v.setVersionName("VName1");

    VersionReleaseComponents vrc = new VersionReleaseComponents();
    vrc.setComponentName("cn1");
    vrc.setVersionNumber("VNum1");
    vrc.setVersion(v);

    Set<VersionReleaseComponents> vrcs = new HashSet<VersionReleaseComponents>();
    vrcs.add(vrc);
    v.setVersionReleaseComponents(vrcs);

    session.saveOrUpdate(v);
于 2013-01-15T14:02:22.280 回答