Hibernate的学习总结(容器映射)

Hibernate中容器主要分为三大类:Set , List , Map

 

要进行容器映射,数据库设计中的表就必须有外键约束。 

 

一.Set容器映射

1个人有许多不重复的邮箱地址。该种逻辑在数据库中一般设计为1张人表和一张邮件地址表。邮件地址表的主键参照人表的主键,人表的主键作为邮件地址表的外键。

在JAVA中其实就是一个人POJO中包含一个容器类型属性mails。只需要设计一个人的POJO实体,而emils表就不必再对应一个实体类了。

相应的建表语句为:

-- 创建表
CREATE TABLE person
(
 id INT AUTO_INCREMENT PRIMARY KEY NOT NULL ,
 name VARCHAR(20)
) ;
CREATE TABLE emails
(
 eid INT  ,
 address VARCHAR(50) ,
 foreign key (id) references person(id) on delete cascade
) ;

 

Person.java

 

Person.hbm.xml

 

但在emails表中定义了外键约束后,对POJO的操作将会同步反映到2张表上。

 

二.List容器映射

例子为:一个人有许多本书,书可能买了一样的,但是买的时候是有先后之分的。同一本书有先后顺序之分。

该映射与Set的区别在于Books的表中会多一个表示先后顺序的索引字段。

建表语句:

-- 创建表
CREATE TABLE person
(
 id INT AUTO_INCREMENT PRIMARY KEY NOT NULL ,
 name VARCHAR(20)
) ;


CREATE TABLE books
(
 id INT  ,
 posit int ,
 title VARCHAR(30) ,
 foreign key (id) references person(id) on delete cascade
) ;

 

Person.java

 

Person.hbm.xml

 

三.Map容器映射

例子:一个人有一个电话薄,电话薄里记录着某个人的姓名和电话,电话薄里面是姓名-电话的MAP关系。

建表语句:

-- 创建表
CREATE TABLE person
(
 id INT AUTO_INCREMENT PRIMARY KEY NOT NULL ,
 name VARCHAR(20)
) ;
CREATE TABLE phone
(
 id INT  ,
 name VARCHAR(20) ,
 numbers VARCHAR(30),
 foreign key (id) references person(id) on delete cascade
) ;

 

Person.java

 

Person.hbm.xml

 

 

 

 

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值