JPA总结——实体关系映射(一对多@OneToMany)

转载 2015年07月09日 18:59:04
一对多模型(单向)
说明: 一个客户对应多个地址,通过客户可以获得该客户的多个地址的信息。客户和地址是一对多的关系,并且客户与地址是单向关联的关系。

映射策略
# 外键关联:两个表的关系定义在一个表中;
# 表关联:两个表的关系单独定义一个表中通过一个中间表来关联。

映射策略——外键关联

表结构如下:
   TABLE customer(id int, name varcher, PRIMARY KEY id)
   TABLE address(id int, address_name varcher, zipcode varcher, city varcher, customer_id int, PRIMARY KEY id)

表address中的customer_id为customer表中的id的值,通过customer_id可以找到相应的customer的记录。
将表customer映射为CustomerEO实体,代码如下:
    @Entity
    @Table(name="customer")
    public class CustomerEO implement Serializable{
        @Id
        @GeneratedValue(stragegy=GenerationType=AUTO)
        private int id;

        @OneToMany(casade={CascadeTypeType.ALL})
        @JoinColumn(name="customer_id")
        public Collection<AddressEO> getAddress() {
              return address;

        }
        ....
    }

一对多@OneToMany注解说明:
@Target({METHOD, FIELD}) @Retention(RUNTIME)
public @interface OneToMany {
    Class targetEntity() default void.class;
    CascadeType[] cascade() default {};
    FetchType fetch() default EAGER;
    String mappedBy() default "";
}
# targetEntity属性表示默认关联的实体类型,默认为当前标注的实体类;
因为一对多的实体集合时保存在集合类中,因此必须指明集合类中保存的具体类型:
1)指定集合泛型的具体类型;如:public Collection<AddressEO> getAddress() {...
2)指定targetEntity属性类型;如:@OneToMany(targetEntity=AddressEO.class,casade={CascadeTypeType.ALL})
# cascade属性表示与此实体一对一关联的实体的联级样式类型。联级样式上当对实体进行操作时的策略。
     说明:在定义关系时经常会涉及是否定义Cascade(级联处理)属性,担心造成负面影响.
        ·不定义,则对关系表不会产生任何影响
        ·CascadeType.PERSIST (级联新建)
        ·CascadeType.REMOVE (级联删除)
        ·CascadeType.REFRESH (级联刷新)
        ·CascadeType.MERGE (级联更新)中选择一个或多个。
        ·还有一个选择是使用CascadeType.ALL ,表示选择全部四项
# fetch属性是该实体的加载方式,有两种:LAZY和EAGER。默认为惰性加载,一般也建议使用惰性加载。
# mappedBy属性用于双向关联实体时使用。

映射策略——表关联
在具体的设计中我们也会使用到使用另外单独的一张表来关联实体关系。比如customer和address例子中,我们增加一张ref_customer_address表保存以上两表的关系。
表结构如下:
   TABLE customer(id int, name varcher, PRIMARY KEY id)
   TABLE address(id int, address_name varcher, zipcode varcher, city varcher, PRIMARY KEY id)
   TABLE ref_customer_address(customer_id int not null, address_id int not null unique)
将表customer映射为CustomerEO实体,代码如下:
    @Entity
    @Table(name="customer")
    public class CustomerEO implement Serializable{
        @Id
        @GeneratedValue(stragegy=GenerationType=AUTO)
        private int id;

        @OneToMany(casade={CascadeTypeType.ALL})
        @JoinTable(name="ref_customer_address",
          joinColumn={@JoinColumn(name="customer_id",referencedColumnName="id")},
          inverseJoinColumn={@JoinColumn(name="address_id",referencedColumnName="id")}
       )

        public Collection<AddressEO> getAddress() {
              return address;

        }
        ....
    }

表关联(@JoinTable)注解说明:
@Target({METHOD, FIELD})
public @interface JoinTable{
    String name() default "";
    String catalog() default "";
    String schema() default "";
    JoinColumn[] joinColumns() default {};
    JoinColumn[] inverseJoinColumns() default {};
    UniqueConstraint[] uniqueConstraints default {};
}
# name属性为连接两个表的表名称。若不指定,则使用默认的表名称,格式如下:
      "表名1" + "_" + "表名2"
# joinColumn属性表示,在保存关系的表中,所保存关联关系的外键的字段,并配合@JoinColumn标记使用;
# inverseJoinColumn属性与joinColumn类似,它保存的是保存关系的另外一个外键字段;
# catalog和schema属性表示实体指定点目录名称或数据库名称;
# uniqueConstraints属性表示该实体所关联的唯一约束条件,一个实体可以有多个唯一约束条件,默认没有约束;

注意:@JoinTable不仅能够定义一对多的关联,也可以定义多对多表的关联。


默认关联
如果使用了表关联,并且该表又设置了外键,则在映射的实体关系时可以使用默认的映射关系设置,举例如下:
表结构如下:
   TABLE customer(id int, name varcher, PRIMARY KEY id)
   TABLE address(id int, address_name varcher, zipcode varcher, city varcher, PRIMARY KEY id)
   TABLE ref_customer_address(customer_id int not null, address_id int not null unique)
   创建customer_id外键
     ALTER TABLE ref_customer_address ADD CONSTRAINT fk_ref_customer FOREIGN KEY (customer_id) REFERENCES customer (id);
   创建address_id外键
     ALTER TABLE ref_customer_address ADD CONSTRAINT fk_ref_address FOREIGN KEY (address_id) REFERENCES address(id);

映射实体CustomerEO的代码如下:
    @Entity
    @Table(name="customer")
    public class CustomerEO implement Serializable{
        @Id
        @GeneratedValue(stragegy=GenerationType=AUTO)
        private int id;

        @OneToMany
        public Collection<AddressEO> getAddress() {
              return address;

        }
        ....
    }

双向一对多(多对一)@OneToMany或@ManyToOne的用法

例如我们用一个例子来开启JPA的一对多和多对一的学习。   比如你去当当网上买书籍,当当网就给你一个订单。   通过上面的业务活动描述你可以分析得出:一个订单可以包含一个或多个订单项.那么我们...
  • Fasure_Smile
  • Fasure_Smile
  • 2016年11月07日 16:41
  • 1805

@ManyToOne和@OneToMany 注解

(1)ManyToOne(多对一)单向:不产生中间表,但可以用@Joincolumn(name="  ")来指定生成外键的名字,外键在多的一方表中产生! (2)OneToMany(一对多)单向:会产...
  • xiaodaiye
  • xiaodaiye
  • 2016年04月11日 08:59
  • 9876

@OneToMany三种设置方式详解

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 2...
  • zq33312757
  • zq33312757
  • 2016年02月25日 15:02
  • 5666

@OneToMany、@ManyToOne以及@ManyToMany讲解

双向一对多关系,一是关系维护端(owner side),多是关系被维护端(inverse side)。在关系被维护端需要通过@JoinColumn建立外键列指向关系维护端的主键列。    ...
  • cx136295988
  • cx136295988
  • 2016年11月03日 01:10
  • 1974

JPA OneToMany和ManyToOne单向实现

博主在学习JPA的过程中,刚开始看到这一部分的时候也很迷惑, OneToMany和ManyToOne这两个注解可以单向实现,也可以双向实现 下面是单向实现方式: 1.@OneToMany 这里使用外健...
  • m0_38031406
  • m0_38031406
  • 2017年06月26日 18:18
  • 1395

Hibernate中ManyToOne,OneToMany,OneToOne的使用例

有3个表: News:新闻表 NewsResource:新闻附件表 Resource:资源表 表关系: 1个新闻(News)对应多条新闻附件(NewsResource) News:ID    New...
  • sunroyi666
  • sunroyi666
  • 2016年07月12日 15:33
  • 5250

@OneToMany或@ManyToOne的用法-annotation关系映射篇(上)

例如我们用一个例子来开启JPA的一对多和多对一的学习。   比如你去当当网上买书籍,当当网就给你一个订单。   通过上面的业务活动描述你可以分析得出:一个订单可以包含一个或多个订单项.那么我们...
  • gebitan505
  • gebitan505
  • 2014年03月30日 23:16
  • 57141

@OneToMany或@ManyToOne的用法-annotation关系映射篇(上)

例如我们用一个例子来开启JPA的一对多和多对一的学习。   比如你去当当网上买书籍,当当网就给你一个订单。   通过上面的业务活动描述你可以分析得出:一个订单可以包含一个或多个订单项.那么...
  • xiaomojun
  • xiaomojun
  • 2016年09月06日 16:22
  • 1941

JPA中的ManyToOne和OneToMany

概念说明 一个用户可以有多个手机,一个手机只能被一个用户使用。这个就是多对一的关系,或者称之为一对多。用户是一,手机是多。外键设置在多这一方(如果不懂,可以百度一下)。具体设置的表如下: ...
  • qq_27575627
  • qq_27575627
  • 2016年11月29日 14:42
  • 2924

JPA总结——实体关系映射(一对多@OneToMany)

注意:本文出自“阿飞”的博客 ,如果要转载本文章,请与作者联系! 并注明来源: http://blog.sina.com.cn/s/blog_49fd52cf0100scql.html 一对多...
  • caiyanzhi123
  • caiyanzhi123
  • 2016年03月08日 16:23
  • 15205
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:JPA总结——实体关系映射(一对多@OneToMany)
举报原因:
原因补充:

(最多只允许输入30个字)