hibernate-2014-02-11

关联关系映射

一对一主键关联映射(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查询)


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值