关联关系映射
一对一主键关联映射(Person(1)-----------(1)IdCard)
对象模型表现形式:
public class Person {
private int id;
private String name;
private IdCard idCard;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public IdCard getIdCard() {
return idCard;
}
public void setIdCard(IdCard idCard) {
this.idCard = idCard;
}
}
public class IdCard {
private int id;
private String name;
private Person person;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Person getPerson() {
return person;
}
public void setPerson(Person person) {
this.person = person;
}
}
mapping file:
Person.hbm.xml
<class name="Person" >
<id name="id">
<generator class="native"/>
</id>
<property name="name"/>
<one-to-one name="idCard"></one-to-one>
</class>
IdCard.hbm.xml(IdCard的主键引用Person的主键,person为主对象,IdCard位从对象)
<class name="IdCard" >
<id name="id">
<generator class="foreign">
<param name="property">person</param>
</generator>
</id>
<property name="name"/>
<one-to-one name="person" constrained="true"></one-to-one>
</class>
在保存对象时可以不告诉主对象从对象是谁,但是一定要告诉从对象主对象是谁。(即idCard.setPerson()一定要调用)
在查询主对象时,从对象会和主对象一起通过关联语句查询出来(一条SQL),而查询从对象则不会一次性查出主对象(只查从对象,如果要使用主对象则在用一条Sql查询)