Внешний ключ, хранящий нулевое значение - PullRequest
0 голосов
/ 04 мая 2018

Я использую Spring boot, JPA для хранения данных в БД для двух реляционных таблиц. Но мой внешний ключ хранит нулевое значение. Ниже мой код.

Контроллер:

@Controller
public class PersistController {

    @Autowired
    private T1Repo t1Repo;

    @GetMapping(value = "/p-save-data")
    @ResponseBody
    public void saveData() {

        T1Entity t1Entity = new T1Entity();
        List<T2Entity> t2Entities = new ArrayList<>();

        T2Entity one = new T2Entity();
        T2Entity two = new T2Entity();
        T2Entity three = new T2Entity();

        one.setT2Name("abc " );
        two.setT2Name("xyz ");
        three.setT2Name("def ");

        t2Entities.add(one);
        t2Entities.add(two);
        t2Entities.add(three);

        t1Entity.setT1Category("jata ");
        t1Entity.setT2Entities(t2Entities);


        t1Repo.save(t1Entity);
        System.out.println("t1 saved " + t1Entity.getT1Id());
    }
}

Модель класса T1Entity:

@Entity
@Table(name = "t1", schema = "jata")
public class T1Entity implements Serializable {

    private int t1Id;
    private String t1Category;
    private List<T2Entity> t2Entities;

    public T1Entity() {
    }

    @OneToMany(targetEntity = T2Entity.class, mappedBy = "t1Entity",
            fetch = FetchType.LAZY, cascade = CascadeType.ALL)
    public List<T2Entity> getT2Entities() {
        return t2Entities;
    }

    public void setT2Entities(List<T2Entity> t2Entities) {
        this.t2Entities = t2Entities;
    }

    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    @Column(name = "t1_id")
    public int getT1Id() {
        return t1Id;
    }

    public void setT1Id(int t1Id) {
        this.t1Id = t1Id;
    }

    @Basic
    @Column(name = "t1_category")
    public String getT1Category() {
        return t1Category;
    }

    public void setT1Category(String t1Category) {
        this.t1Category = t1Category;
    }

}

Модель класса T2Entity:

@Entity
@Table(name = "t2", schema = "jata")
public class T2Entity implements Serializable {

    private int t2Id;
    private String t2Name;
    private T1Entity t1Entity;

    public T2Entity() {
    }

    @ManyToOne
    @JoinColumn(name = "t2_fk_t1_id", referencedColumnName = "t1_id")
    public T1Entity getT1Entity() {
        return t1Entity;
    }

    public void setT1Entity(T1Entity t1Entity) {
        this.t1Entity = t1Entity;
    }

    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    @Column(name = "t2_id")
    public int getT2Id() {
        return t2Id;
    }

    public void setT2Id(int t2Id) {
        this.t2Id = t2Id;
    }

    @Basic
    @Column(name = "t2_name", length = 50)
    public String getT2Name() {
        return t2Name;
    }

    public void setT2Name(String t2Name) {
        this.t2Name = t2Name;
    }


}

Репозиторий для обоих классов модели:

@Repository
public interface T1Repo extends JpaRepository<T1Entity, Integer> {
}

@Repository
public interface T2Repo extends JpaRepository<T2Entity,Integer> {
}

Мои данные хранятся как в таблице t1, так и в t2, но поле внешнего ключа равно нулю. Пожалуйста, помогите мне решить проблему.

1 Ответ

0 голосов
/ 04 мая 2018

Вам необходимо установить T1Entity ссылку на сущность в T2Entity (дочерней) сущности. Так что ниже будет ваш код в контроллере -

@Autowired
private T1Repo t1Repo;

@GetMapping(value = "/p-save-data")
@ResponseBody
public void saveData() {

    T1Entity t1Entity = new T1Entity();
    List<T2Entity> t2Entities = new ArrayList<>();

    T2Entity one = new T2Entity();
    T2Entity two = new T2Entity();
    T2Entity three = new T2Entity();

    one.setT2Name("abc " );
    one.setT1Entity(t1Entity ); //newly added line
    two.setT2Name("xyz ");
    two.setT1Entity(t1Entity ); //newly added line
    three.setT2Name("def ");
    three.setT1Entity(t1Entity ); //newly added line

    t2Entities.add(one);
    t2Entities.add(two);
    t2Entities.add(three);

    t1Entity.setT1Category("jata ");
    t1Entity.setT2Entities(t2Entities);


    t1Repo.save(t1Entity);
    System.out.println("t1 saved " + t1Entity.getT1Id());
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...