Подтвердить что ты не робот

Как сопоставить один класс с несколькими таблицами в Hibernate/javax.persistance?

Я хочу использовать один класс для сопоставления трех таблиц. Я знаю, что javax.persistance предоставляет аннотацию @SecondaryTable для сопоставления двух таблиц одному классу.

Ниже приведен код, в котором я использовал @SecondaryTable. Это позволяет мне определить только одну вторичную таблицу. Но мне нужны 3 таблицы, которые будут использоваться одним и тем же классом.

@Entity
@Table(name = "table1")
@SecondaryTable(name="table2")
public class TableConfig
    implements Serializable {

    /**
     * 
     */
    private static final long serialVersionUID = 1L;

    @Id
    @Column(name = "mac", table= "table1")
    private String uniqueIdentifier;
4b9b3361

Ответ 1

Я хочу использовать один класс для сопоставления трех таблиц. Из того, что я знаю, это то, что javax.persistance предоставляет аннотацию @SecondaryTable для сопоставления двух таблиц с одним классом

используйте @Средние таблицы для сопоставления нескольких таблиц.

Вы можете сопоставить единый объект bean с несколькими таблицами, используя аннотации уровня @SecondaryTables. Чтобы выразить, что столбец находится в конкретной таблице, используйте параметр таблицы @Column или @JoinColumn.


например, существует 3 объекта, а именно: Name, Address и Student:

Name объект будет выглядеть так:

@Entity
@Table(name="name")
public class Name implements Serializable {

    @Id
    @Column(name="id")
    private int id;
    @Column(name="name")
    private String name;

    public Name(){}

    public Name(int id,String name){
        this.id=id;
        this.name=name;
    }
        //getters and setters
}

Address объект будет выглядеть так:

@Entity
@Table(name="address")
public class Address implements Serializable {

    @Id
    @Column(name="id")
    private int id;
    @Column(name="address")
    private String address;

    public Address(){}

    public Address(int id, String address) {
        super();
        this.id = id;
        this.address = address;
    }
        //getters and setters
}

Student объект будет выглядеть так:

@Entity
@Table(name="student")
@SecondaryTables({
    @SecondaryTable(name="name", pkJoinColumns={
        @PrimaryKeyJoinColumn(name="id", referencedColumnName="student_id") }),
    @SecondaryTable(name="address", pkJoinColumns={
        @PrimaryKeyJoinColumn(name="id", referencedColumnName="student_id") })
})
public class Student implements Serializable {

    @Id
    @Column(name="student_id")
    private int studentId;

    @Column(table="name")
    private String name;

    @Column(table="address")
    private String address;

    public Student(){}

    public Student(int studentId){
        this.studentId=studentId;
    }
        //getters and setters
}

Хранить как:

    Student s= new Student(1);
    session.save(s);

    Name n=new Name(s.getStudentId(),"Bilal Hasan");
    session.save(n);    

    Address address = new Address(s.getStudentId(), "India");
    session.save(address);

    Student ob = (Student)session.get(Student.class, s.getStudentId());

    System.out.println(ob.getStudentId());
    System.out.println(ob.getName());
    System.out.println(ob.getAddress());

Ouput:

1
Bilal Hasan
India

Ответ 2

вы можете определить один класс, как показано ниже:

@Entity
@Table(name="table1")
@SecondaryTables({
      @SecondaryTable(name="table2", pkColumnJoins={@PrimaryKeyJoinColumn(name = "id")}),
      @SecondaryTable(name="table3", pkColumnJoins={@PrimaryKeyJoinColumn(name = "id")})
  })
public class TestEntity {
      @Id
      @GeneratedValue
      private int id;

      private String field1;

      @Column(name="column2", table="table2")
      private String field2;

      @Column(name="column3", table="table3")
      private String field3;

      getter and setter...
}

В вашей базе данных должно быть три таблицы, и все они должны иметь один и тот же первичный ключ "id".

то использование может протестировать следующим образом:

TestEntity test = new TestEntity();
test.setField1("field1");
test.setField2("field2");
test.setField3("field3");

em.merge(test);

после теста в вашей БД вы найдете по одной записи в каждой таблице:

table1:

 1, field1

table2:

 1, field2

Таблица3:

 1, field3

все они будут использовать значение первичного ключа. Надеюсь, это поможет вам.

Ответ 3

В файле сопоставления Hibernate вы можете указать сопоставление имени сущности с виртуальным именем вместе с полиморфизмом = "явным", а имя класса будет физическим именем класса. Подобно этому вы можете делать несколько сопоставлений. При загрузке объекта используйте имя объекта (виртуальное имя).