1)Customer Order(一对多)
一个用户对应多个订单。
(1)主表:Customer
要配置:
<set name="orders" lazy="true" cascade="all">
<key column="c_id"/>
<one-to-many class="Order" />
</set>
<!-- 不延迟加载lazy="false" 默认是延迟加载-->
(2)从表:Order
要配置:
<many-to-one class="Customer" name="customer"
column="c_id"/>
设置关联关系都是有外键的表来设置的
String hql="from Customer where name=?";
Query query=session.createQuery(hql);
query.setString(0, "张三");
Customer cust=(Customer) query.uniqueResult();
Order order1=new Order(null,"146.5",new Date());
Order order2=new Order(null,"246.5",new Date());
order1.setCustomer(cust);
order2.setCustomer(cust); 这里才设置关联属性
session.save(order1);
session.save(order2);
映射文件的配置
(1) name: 属性的名字。这个类的属性的名字,而且是与之关联的属性的名字
(2) class (可选 - 默认是通过反射得到的属性类型):被关联的类的名字。
(3) cascade(级联) (可选):表明操作是否从父对象级联到被关联的对象。
(4) constrained(约束) (可选):表明该类对应的表对应的数据库表,和被关联的对象所对应的数据库表之间,通过一个外键引用对主键进行约束。
这个选项影响save()和delete()在级联执行时的先后顺序
以及决定该关联能否被委托(也在schema export tool中被使用).
(5) fetch (可选 - 默认设置为选择): 在外连接抓取或者序列选择抓取选择其一.
(6) property-ref (可选):指定关联类的属性名,这个属性将会和本类的主键相对应。
如果没有指定,会使用对方关联类的主键。
(7) access (可选 - 默认是 property): Hibernate用来访问属性的策略。
(8) formula (可选):绝大多数一对一的关联都指向其实体的主键。
在一些少见的情况中, 你可能会指向其他的一个或多个字段,或者是一个表达式,
这些情况下,你可以用一个SQL公式来表示。
(可以在org.hibernate.test.onetooneformula找到例子)
(9) lazy (可选 - 默认为 proxy): 默认情况下,单点关联是经过代理的。lazy="no-proxy"指定此属性应该在实例变量第一次被访问时应该延迟抓取(fetche lazily)(需要运行时字节码的增强)。 lazy="false"指定此关联总是被预先抓取。注意,如果constrained="false", 不可能使用代理,Hibernate会采取预先抓取!
(10) entity-name (可选): 被关联的类的实体名。
2)一对一:person(人) card(身份证)
(1)有两种表示一对一映射的方法:
1,从表中设置外键的方式
从表:Card类的配置
<many-to-one name="person" class="Person" unique="true" column="p_id" />
主表:Person
<one-to-one name="card" class="Card" property-ref="person"/>
property-ref:如果没有设置就会出现错误,比如1---1和2---2
人为的改为
property-ref:没写它匹配的就是card表中的主键
property-ref:写了就是匹配person表中的主键
** 在这里面就是有外键的表Card中设置关联**
Card card=new Card(null,"1111","nanchang");
card.setPerson(p);
**2,主表和从表的主键保持一致**
从表:Card
<generator class="foreign">表示card的主键参照的就是person的主键。
<param name="property">person</param>
</generator> <one-to-one name="person" class="Person" constrained="true"/>//constrained设置约束是为防止被人为的修改造成混乱。
主表:Person
<one-to-one name="card" class="Card" property-ref="person"/>
3)多对多:课程和学生
Course:
<set name="students" table="tbl_student_course">
<key column="c_id"></key>
<many-to-many class="Student" column="s_id"/>
</set>
Student:
<set name="course" table="tbl_student_course">
<key column="s_id"></key>
<many-to-many class="Course" column="c_id"/>
</set>