Hibernate的单向1-1关联(二)

1. 基于外键的单向1-1关联

对于基于外键的1-1关联而言,只要先使用@OneToOne注解修饰代表关联关系实体的属性,再使用@JoinColumn映射外键列即可——由于是1-1关联,因此应该为@JoinColumn增加unique=true。下面是Person类的代码。

@Entity
@Table(name="person_inf")
public class Person
{
	// 标识属性
	@Id @Column(name="person_id")
	@GeneratedValue(strategy=GenerationType.IDENTITY)
	private Integer id;
	private String name;
	private int age;
	// 定义该Person实体关联的Address实体
	@OneToOne(targetEntity=Address.class)
	// 映射名为address_id的外键列,参照关联实体对应表的addres_id主键列
	@JoinColumn(name="address_id"
		, referencedColumnName="address_id" , unique=true)
	private Address address;

	// id的setter和getter方法
	public void setId(Integer id)
	{
		this.id = id;
	}
	public Integer getId()
	{
		return this.id;
	}

	// name的setter和getter方法
	public void setName(String name)
	{
		this.name = name;
	}
	public String getName()
	{
		return this.name;
	}

	// age的setter和getter方法
	public void setAge(int age)
	{
		this.age = age;
	}
	public int getAge()
	{
		return this.age;
	}

	// address的setter和getter方法
	public void setAddress(Address address)
	{
		this.address = address;
	}
	public Address getAddress()
	{
		return this.address;
	}
}

下面是Address的类代码。

@Entity
@Table(name="address_inf")
public class Address
{
	// 标识属性
	@Id @Column(name="address_id")
	@GeneratedValue(strategy=GenerationType.IDENTITY)
	private int addressId;
	// 定义地址详细信息的成员变量
	private String addressDetail;

	// 无参数的构造器
	public Address()
	{
	}
	// 初始化全部成员变量的构造器
	public Address(String addressDetail)
	{
		this.addressDetail = addressDetail;
	}

	// addressId的setter和getter方法
	public void setAddressId(int addressId)
	{
		this.addressId = addressId;
	}
	public int getAddressId()
	{
		return this.addressId;
	}

	// addressDetail的setter和getter方法
	public void setAddressDetail(String addressDetail)
	{
		this.addressDetail = addressDetail;
	}
	public String getAddressDetail()
	{
		return this.addressDetail;
	}
}
我们使用如下的类来保存数据。

public class PersonManager
{
	public static void main(String[] args)
	{
		PersonManager mgr = new PersonManager();
		mgr.testPerson();
		HibernateUtil.sessionFactory.close();
	}

	private void testPerson()
	{
		Session session = HibernateUtil.currentSession();
		Transaction tx = session.beginTransaction();
		// 创建一个Person对象
		Person p = new Person();
		// 设置Person的name为owen字符串
		p.setName("owen");
		p.setAge(21);
		// 创建一个瞬态的Address对象
		Address a = new Address("广州天河");
		// 通过Person对象建立它自己与Address实体的关联关系
		p.setAddress(a);
		// 先持久化Address对象(对应为插入主表记录)
		session.persist(a);
		// 再持久化Person对象(对应为插入从表记录)
		session.save(p);
		tx.commit();
		HibernateUtil.closeSession();
	}
}

执行结果图如下:



2. 有连接表的单向1-1关联

有连接表的1-1关联同样需要显示使用@JoinTable映射连接表。除此之外,由于此处的@JoinTable 映射的连接表维护的是1-1关联,因此程序需要为@JoinTable 中joinColumns属性映射的外键增加unique=true,也为inverseJoinColumns属性映射的外键增加unique=true。下面是Person类使用了@OneToOne和@JoinTable修饰代表关联实体的Address类型的属性。

// 标识属性
	@Id @Column(name="person_id")
	@GeneratedValue(strategy=GenerationType.IDENTITY)
	private Integer id;
	private String name;
	private int age;
	// 定义该Person实体关联的Address实体
	@OneToOne(targetEntity=Address.class)
	// 显式使用@JoinTable映射连接表
	@JoinTable(name="person_address", // 指定连接表的表名为person_address
		// 指定连接表中person_id外键列,参照到当前实体对应表的主键列
		joinColumns=@JoinColumn(name="person_id"
			, referencedColumnName="person_id", unique=true),
		// 指定连接表中address_id外键列,参照到当前实体的关联实体对应表的主键列
		inverseJoinColumns=@JoinColumn(name="address_id"
			, referencedColumnName="address_id", unique=true)
	)



你可能感兴趣的:(java,Hibernate,jsp,ssh,Web应用)