11hibernate hibernate的关系映射之OneToMany和ManyToOne(重点)

1.多对一单向关联
	a.数据库表设计,在多方加外键(原则:不要产生数据冗余)
	补充知识——数据库表设计三范式:
		(1)要有主键,列不可分
		(2)联合主键不能存在部分依赖
		(3)不能存在传递依赖

	b.annotation:
		@Entity
		@Table(name="t_group")
		public class Group
		{
			@Id
			@GeneratedValue
			private int id;
			private String name;
		}
		@Entity
		@Table(name="t_user")
		public class User
		{
			@Id
			@GeneratedValue
			private int id;
			private String name;
			@ManyToOne
			private Group group;
		}

	c.xml:<many-to-one></many-to-one>
		<class name="com.hibernate.Group" table="t_group">
			<id name="id">
				<generator class="native"></generator>
			</id>
			<property name="name"></property>
		</class>

		<class name="com.hibernate.User" table="t_user">
			<id name="id">
				<generator class="native"></generator>
			</id>
			<property name="name"></property>
			<many-to-one name="group" column="groupId"></many-to-one>
			//此处的name是属性名
		</class>


2.一对多单向关联
	a.数据库表设计,在多方加外键
	b.类:在一的一方存在多方的集合
	c.annotation:
		@Entity
		@Table(name="t_group")
		public class Group
		{
			@Id
			@GeneratedValue
			private int id;
			private String name;
			@OneToMany
			@JoinColumn(name="groupId")//进行映射
			private Set<User> users = new HashSet<User>(); 
			//数据库表数据不应该有重复,用set最合适
			//没有@JoinColumn(name="groupId")会生成中间临时表
		}

	d.xml:
		<class name="com.hibernate.Group" table="t_group">
			<id name="id">
				<generator class="native"></generator>
			</id>
			<property name="name"></property>
			<set name="users">
				<key column="groupId"></key>
				<one-to-many class="com.hibernate.User"></one-to-many>
			</set>
		</class>

3.一对多(多对一)双向关联
	a.annotation
		@Entity
		@Table(name="t_group")
		public class Group
		{
			@Id
			@GeneratedValue
			private int id;
			private String name;
			@OneToMany(mappedBy="group")
			private Set<User> users = new HashSet<User>(); 
			//在数据库表中关联关系设在多方
			//所以User作为主导
		}

		@Entity
		@Table(name="t_user")
		public class User
		{
			@Id
			@GeneratedValue
			private int id;
			private String name;
			@ManyToOne
			private Group group;
		}

	b.xml:
		<class name="com.hibernate.User" table="t_user">
			<id name="id">
				<generator class="native"></generator>
			</id>
			<property name="name"></property>
			<many-to-one name="group" column="groupId"></many-to-one>
			//name="group"是外键名称,此处的name是属性名
			//两处设置的column名称必须一致
		</class>
		<class name="com.hibernate.Group" table="t_group">
			<id name="id">
				<generator class="native"></generator>
			</id>
			<property name="name"></property>
			<set name="users">
				<key column="groupId"></key>
				<one-to-many class="com.hibernate.User"></one-to-many>
			</set>
		</class>


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值