短縮版
Hibernate は 1 対 1 の関係を取得するために 2 つだけではなく複数の選択クエリを実行しています
ロングバージョン
人物クラス:
@Entity
@Table(name = "people")
public class Person{
@Id
@GeneratedValue
@Column
private Integer id;
@Column
private String name;
@OneToOne(optional=false, fetch=FetchType.EAGER)
private Job job;
}
ジョブ クラス:
@Entity
@Table(name = "jobs")
public class Job{
@Id
@GeneratedValue
@Column
private Integer id;
@Column
private String name;
}
すべての人とその仕事を表示する:
Session session = HibernateUtil.getSessionFactory().getCurrentSession();
session.beginTransaction();
List<Person> people = session.createQuery("from Person").list();
for(Person p : people){
System.out.println(p.getName() + " | " + p.getJob().getName());
}
私が期待したこと: 2 つの選択、1 つは 5 人用、もう 1 つは 3 つの異なる仕事用 (3 人が同じ仕事をしています)
私が得たもの: People 用に 1 つ、それぞれの異なる Job 用に 3 つの 4 つの選択
Hibernate: select person0_.id as id1_, person0_.job_id as job3_1_, person0_.name as name1_ from people person0_
Hibernate: select job0_.id as id0_0_, job0_.name as name0_0_ from jobs job0_ where job0_.id=?
Hibernate: select job0_.id as id0_0_, job0_.name as name0_0_ from jobs job0_ where job0_.id=?
Hibernate: select job0_.id as id0_0_, job0_.name as name0_0_ from jobs job0_ where job0_.id=?
Jim | Programmer
Andrew | DBA
Tomas | Sysadmin
Henry | Sysadmin
Jerry | Sysadmin
1,000 の異なるジョブを持つ 1,000 人がいる場合、1,000 の選択が実行されていることがわかります。Hibernate が 2 つの選択のみを行うようにするにはどうすればよいですか?
ありがとう