Hibernate2

对象状态
瞬时(transient):数据库中没有数据与之对应,超过作用域会被JVM垃圾回收器回收,一般是new出来且与session没有关联的对象。
持久(persistent):数据库中可能有数据与之对应,当前与session有关联,并且相关联的session没有关闭,事务没有提交; 持久对象状态发生改变,在事务提交时会影响到数据库(hibernate能检测到)
脱管(detached):数据库中可能有数据与之对应,但当前没有session与之关联;托管对象状态发生改变,hibernate不能检测到。
操纵持久化对象-save()
Session 的 save() 方法使一个临时对象转变为持久化对象
Session 的 save() 方法完成以下操作:
把 News 对象加入到 Session 缓存中, 使它进入持久化状态
选用映射文件指定的标识符生成器, 为持久化对象分配唯一的 OID. 在使用代理主键的情况下, setId() 方法为 News 对象设置 OID 使无效的.
Hibernate 通过持久化对象的 OID 来维持它和数据库相关记录的对应关系. 当 News 对象处于持久化状态时, 不允许程序随意修改它的 ID
计划执行一条 insert 语句,把Customer对象当前的属性值组装到insert语句中。只有当Session清理缓存时,才会执行SQL insert语句。如果在save()方法之后,修改了持久化对象的属性值,Session清理缓存时会额外执行SQL update语句。
操纵持久化对象-update()
Session 的 update() 方法使一个游离对象转变为持久化对象, 并且计划执行一条 update 语句.
操纵持久化对象-saveOrupdate()
saveOrUpdate:
  该方法同时包含save和update方法,如果参数是临时对象就用save方法,如果是游离对象就用update方法,如果是持久化对象就直接返回。
HQL(Hibernate Query Language)
面向对象的查询语言,与SQL不同,HQL中的对象名是区分大小写的(除了JAVA类和属性其他部分不区分大小写);HQL中查的是对象而不是和表,并且支持多态;HQL主要通过Query来操作,Query的创建方式:
Query q = session.createQuery(hql);
lfrom Person
lfrom User user where user.name=:name
lfrom User user where user.name=:name and user.birthday < :birthday
Criteria
Criteria是一种比HQL更面向对象的查询方式;Criteria的创建方式:
Criteria crit = session.createCriteria(DomainClass.class);
简单属性条件如:criteria.add(Restrictions.eq(propertyName, value)),
criteria.add(Restrictions.eqProperty(propertyName,otherPropertyName))
 
 
多对一(Employee - Department)
映射文件<many-to-one name=”depart” column=”depart_id”/>
一对多(Department-Employee)
<set name=”employees”>
<key column=”depart_id”/>
<one-to-many class=”Employee”/>
</set>
 
单向一对一: (公民与身份证)
方式一:基于唯一外键
Citizen.hbm.xml
<many-to-one name=“idCard” column=“idCard_id” unique=“true” cascade=“all”/>
方式二:基于主键
Citizen.hbm.xml:
<id name=“id” column=“id”>
  <generator class=“foreign”>
     <param name=“property”>idCard</param>
   </generator>
</id>
….
<one-to-one name=“idCard” constrained=“true” cascade=“all”/>
双向一对一:基于唯一外键 ;   基于主键
public class Citizen {
private Long id;
private String name;           
private boolean gender;        
private IDCard idCard; …}
public class IDCard {
private Long id;)
private String no;
private Citizen citizen; …}
对于基于唯一外键的一对一关联,其外键可以放在任意一端,在需要存放外键的一端,使用many-to-one元素,添加unqiue=true;没有存放外键的那一端需要使用one-to-one元素,此时还需要通过property-ref属性来指定这一端只是关联另一端,不需要额外的列或外键,由hibernate管理这个关系。
Citizen.hbm.xml
<many-to-one name=“idCard” column=“idCard_id” unique=“true” cascade=“all”/>
IDCard.hbm.xml
<one-to-one name=“citizen” property-ref=“idCard”/>
基于主键,一端的主键使用foreign策略来参照另一端的主键来生成。这样两端就具有相同的主键值。
 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值