第6章 深入使用Hibernate2_第1页
第6章 深入使用Hibernate2_第2页
第6章 深入使用Hibernate2_第3页
第6章 深入使用Hibernate2_第4页
第6章 深入使用Hibernate2_第5页
已阅读5页,还剩20页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

第六章深入使用Hibernate提纲1关联映射2继承映射3批量处理4HQL查询5条件查询6SQL查询7数据过滤8事务控制9二级缓存/查询缓存10事件机制1关联映射单向关联(只对一个POJO有要求,其它不管)N-11-11-NN-N双向关联1-11-N(等同于N-1)N-N(1)单向N-1关联从N端访问1端,例如多个人有同一个地址N-1关联,需要在N端使用@ManyToOne修饰关联属性@cascade---指定级联策略,CascadeType.ALL将所有持久化操作都级联到关联实体,CascadeType.XX将指定的XX操作进行级联@fetch---抓取策略,FetchType.EAGER为默认值(立即抓取),可改为延迟抓取LAZY无连接表的N-1关联(常用)只在N端增加一列外键,使用@JoinColumn修饰代表关联实体的属性Person.java(主表)@ManyToOne(targetEntity=Adr.class)@JoinColumn(name=“adr_id”,nullable=false)@Cascade(CascadeType.ALL)

privateAdradr;Test.java

Personp=newPerson();Adra1=newAdr(“abc”);

p.setAddress(a1);sess.persist(p);Adra2=newAdr(“xyz”);

p.setAddress(a2);mit(p);sess.close();有连接表的N-1关联只在N端增加一列外键,使用@JoinColumn修饰代表关联实体的属性Person.java(无主从表,多人一址)@ManyToOne(targetEntity=Adr.class)@JoinTable(name=“person_adr”,joinColumn=@JoinColumn(name=“person_id”,

referenceColumnName=“person_id”,unique=true),

inverseJoinColumn=@JoinCloumn(name=“adr_id”,

referenceColumnName=“adr_id”))privateAdradr;(2)单向1-1关联单向一对一,例如一个人只能有一个地址在1个持久化类中增加代表关联实体的成员变量,及相应的set/get方法使用@OneToOne修饰关联属性mappedBy—指定关联实体中可引入到当前实体的属性orphanRemoval—是否删除孤儿实体(如果父实体不存在/为null,该实体就是孤儿实体)基于外键的单向1-1关联(常用)只在使用@OneToOne修饰关联属性,再用@JoinColumn映射外键列,并设置unique=truePerson.java(主表)@OneToOne(targetEntity=Address.class)@JoinColumn(name=“address_id”,referenceColumnName=“address_id”,unique=true)privateAdradr;有连接表的单向1-1关联先使用@OneToOne修饰关联属性,再用@JoinTable映射连接表,并设置unique=trueinverseJoinColumns也要设置unique=truePerson.java(一人一址)

@OneToOne(targetEntity=Adr.class)@JoinTable(name=“person_adr”,

joinColumns=@JoinColumn(name=“person_id”,referenceColumnName=“person_id”,unique=true),

inverseJoinColumns=@JoinCloumn(name=“adr_id”,referenceColumnName=“adr_id”,unique=true))privateAdradr;(3)单向1-N关联单向一对多,例如一个人有多个地址在1端有Set类型成员,有相应的set/get方法使用@OneToMany修饰关联属性mappedBy—指定关联实体中可引入到当前实体的属性orphanRemoval—是否删除孤儿实体(如果父实体不存在/为null,该实体就是孤儿实体)无连接表的单向1-N关联(尽量不用)在1端使用@OneToMany修饰关联属性,再用@JoinColumn修饰Set集合属性,映射外键Person.java(主表)@OneToMany(targetEntity=Address.class)@JoinColumn(name=“person_id”,referenceColumnName=“person_id”)privateSet<Address>adrs=newHashSet<Address>();Test.java

Personp=newPerson();Adra1=newAdr(“abc”);sess.persist(a);

p.getAdr().add(a1);sess.save(p);Adra2=newAdr(“xyz”);

sess.persist(a2);p.getAdr().add(a2);mit(p);sess.close();有连接表的单向1-N关联(推荐)先使用@OneToMany修饰关联属性,再用@JoinTable指定连接表Person.java(一人多址)

@OneToMany(targetEntity=Adr.class)@JoinTable(name=“person_adr”,

joinColumns=@JoinColumn(name=“person_id”,referenceColumnName=“person_id”),

inverseJoinColumns=@JoinCloumn(name=“adr_id”,referenceColumnName=“adr_id”,unique=true))privateSet<Address>adrs=newHashSet<Address>();(4)有连接表的单向N-N关联N-N必须使用连接表,在控制端要用@ManyToMany修饰集合属性,再用@JoinTable指定连接表Person.java(一人多址)

@ManyToMany(targetEntity=Adr.class)@JoinTable(name=“person_adr”,

joinColumns=@JoinColumn(name=“person_id”,referenceColumnName=“person_id”),

inverseJoinColumns=@JoinCloumn(name=“adr_id”,referenceColumnName=“adr_id”,unique=true))privateSet<Address>adrs=newHashSet<Address>();课堂练习及作业请以小组形式,建立下面二个类,并实现几种常用的单向关联:无连接表的N-1关联基于外键的单向1-1关联有连接表的单向1-N关联有连接表的单向N-N关联用户类,包含:ID,姓名,性别,电话电话类:ID,手机,座机(5)双向1-N关联1-N关联,推荐使用双向方式,而且不让1端控制,由N端控制使用@OneToMany、@ManyToOne时若指定了mappedBy属性,则该实体不能作为控制端@OneToMany、@ManyToOne、@OneToOne所在实体放弃了控制关联,则不可使用@JoinCloumn、@JoinTable修饰无连接表的双向1-N关联在1端增加集合属性,在N端增加引用属性Person.java--1端@OneToMany(targetEntity=Address.class,mappedBy=“person”)privateSet<Address>adrs=newHashSet<>();Address.java--N端(控制端)@ManyToOne(targetEntity=Person.class)@JoinColumn(name=“person_id”,referencedColumnName=“person_id”,nullable=false)privatePersonperson;有连接表的双向1-N关联在N端增加引用属性,在1端增加集合属性Person.java--若做控制端则去掉mappedBy属性@OneToMany(targetEntity=Address.class,mappedBy=“person”)@JoinTable(name=“person_address”,joinClumns=@JoinCloumn(name=“person_id”,referencedColumnName=“person_id”),inverseJoinCloumns=@JoinCloumn(name=“address_id”,referenceColumnName=“address_id”,unique=true))privateSet<Address>adrs=newHashSet<>();Address.java@ManyToOne(targetEntity=Person.class)@JoinTable(name=“person_address”,joinClumns=@JoinCloumn(name=“address_id”,referencedColumnName=“address_id”,unique=true),inverseJoinCloumns=@JoinCloumn(name=“person_id”,referenceColumnName=“person_id”))privatePersonperson;(6)双向N-N关联两端都使用集合属性,都增加对集合属性的访问只能通过连接表来关联要有无参构造方法两端都使用@ManyToMany注解有连接表的双向N-N关联Person.java@ManyToMany(targetEntity=Address.class)@JoinTable(name=“person_address”,joinClumns=@JoinCloumn(name=“person_id”,referencedColumnName=“person_id”),inverseJoinCloumns=@JoinCloumn(name=“address_id”,referenceColumnName=“address_id”))privateSet<Address>adrs=newHashSet<>();Address.java@ManyToMany(targetEntity=Person.class)@JoinTableJoinTable(name=“person_address”,joinClumns=@JoinCloumn(name=“address_id”,referencedColumnName=“address_id”),inverseJoinCloumns=@JoinCloumn(name=“person_id”,referenceColumnName=“person_id”))privateSet<Person>person=newHashset<>();(7)双向1-1关联在两个类都要增加引用对方属性,并提供相应的set/get方法两端都使用@OneToOne注解基于外键的双向1-1关联(常用)在1端增加外键及引用,在另一1端增加引用Person.java--1端@OneToOne(targetEntity=Address.class,mappedBy=“person”)PrivateAddressaddress;Address.java--1端(控制端)@OneToOne(targetEntity=Person.class)@JoinColumn(name=“person_id”,referenceColumnName=“person_id”,unique=true)privatePersonperson;有连接表的双向1-1关联(不常用)二端都加@JoinTablePerson.java@OneToOne(targetEntity=Address.class)@JoinTable(name=“person_address”,joinClumns=@JoinCloumn(name=“person_id”,referencedColumnName=“person_id”,unique=true),inverseJoinCloumns=@JoinCloumn(name=“address_id”,referenceColumnName=“address_id”,unique=true))privateAddressaddress;Address.java@OneToOne(targetEntity=Person.class)@JoinTable(name=“person_address”,joinClumns=@JoinCloumn(name=“address_id”,referencedColumnName=“address_id”,unique=true),inverseJoinCloumns=@JoinCloumn(name=“person_id”,referen

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论