hibernate对象状态

1. Transient Objects临时对象
Objects instantiated using the new operator aren't immediately persistent. Their state is transient, which means they aren't associated with any database table row, and so their state is lost as soon as they're dereferenced.
新生成的对象, Session没有引用指向它, 没有放入session缓存中,它在数据库里没有相对应的数据

2. Persist Objects持久化对象
A persistent instance is any instance with a database identity. Persistent instances are associated with the persistence manager. Persistent instances are always associated with a Session and are transactional
   放入session缓存中,Session有引用指向该对象, 它在数据库里有相对应的数据, 与数据库里的数据同步

3. Detached Objects游离对象
   Instances lose their association with the persistence manager when you close() the Session. We refer to these objects as detached, indicating that their state is no longer guaranteed to be synchronized with database state; they're no longer under the management of Hibernate.
   已经被持久化,但不再处于session缓存中,Session已没有引用指向该对象, 数据库里可能还有相对应的数据, 但已不能与数据库里的数据同步


Teacher tt=new Teacher();   // tt 指向 Transient Object临时对象
tt.setName("zhang");
tt.setSex("male");

Session session = sf.openSession();
Transaction tx = session.beginTransaction();
session.save(tt)// tt指向的临时对象转变成持久化对象, 存入对象的数据到数据库里
tx.commit();   
session.close(); // tt指向的持久化对象转变成游离对象
tt=null;    // tt指向 null, 原来tt指向的对象已没有任何引用指向它, 可以被垃圾回收掉


Session session = sf.openSession();
Transaction tx = session.beginTransaction();
Teacher t=(Teacher) session.get(Teacher.class, new Integer(id)); //从数据库里获得数据生成对象, t指向持久化对象
tx.commit();   
session.close();

t.setName("wang"); // t指向Detached Object游离对象

Session session2 = sf.openSession();
Transaction tx = session2.beginTransaction();
session2.update(t); // t指向的游离对象转变成持久化对象, 用对象的数据改变数据库里相应的记录
tx.commit();
session2.close();

t.setName("chen"); // t指向的持久化对象转变成游离对象

------------------------------------------------------------
Transition among States 对象状态转换

* new   产生 Transient Objects临时对象

* Transient Objects临时对象   -->   Persist Objects持久化对象
     save(?), saveOrUpdate(?)

* Persist Objects持久化对象   -->   Transient Objects临时对象
     delete(?)

* Persist Objects持久化对象   -->   Detached Objects游离对象
     evict(?), close(), clear()   //evict() 从Session清除一个对象, clear() 从Session清除所有对象

* Detached Objects游离对象    -->   Persist Objects持久化对象
     update(?), saveOrUpdate(?), lock(?) // lock()方法是用来让应用程序把一个未修改的对象重新关联到新session的方法

*    get(?), load(?), find(?), iterator() 从数据库里获得数据, 加载Persist Objects持久化对象

---------------------------------------
Session 的保存, 更新, 删除, 和查询方法

1. save(?): Transient Objects临时对象   --->   Persist Objects持久化对象
         把临时对象加入缓存, 变成持久化对象
         为持久化对象分配唯一的OID,
         计划一个insert语句
         只有当Session清理缓存时, 才会执行SQL的insert语句
        
         !!!在应用程序中不应把Persist Objects持久化对象或Detached Objects游离对象传给save().
              对于Persist Objects持久化对象 , 操作多余
              对于Detached Objects游离对象, 会导致表里有两条代表相同业务的记录,不符合业务逻辑

2. update(?) : Detached Objects游离对象    --->   Persist Objects持久化对象
         把游离对象重新加入缓存, 变成持久化对象
         如果传入的参数是持久化对象, Session 计划一个update语句
         如果传入的参数是游离对象, 游离对象重新加入缓存, 变成持久化对象, 然后 Session 计划一个update语句
        
         只有当Sessio清理缓存时, 才会执行SQL的update语句
         !!!! 如果在Session缓存中已经存在与该游离对象相同OID的持久化对象,该游离对象不能加入缓存, Session会抛异常
              此外, 当update()关联一个游离对象时, 如果数据库里不存在相应的记录, 也会抛异常


3. delete(?): Persist Objects持久化对象   ->   Transient Objects临时对象
       用于从数据库里删除与对象对应的记录.
      
       只有当Sessio清理缓存时, 才会执行SQL的delete语句

4. load(?) 和 get(?): 根据OID从加载数据库里加载 Persist Objects持久化对象
       区别: 当数据库里不存在与OID相应的记录, load()抛异常
                                               get()返回null


**********************************************************
**********************************************************

Transaction 事务处理: 处理一组互相依赖的操作行为

   数据库事务是指由一个或多个SQL语句组成的工作单元
   数据库事务具有ACID特性, 由关系数据库管理系统(RDBMS)实现.

   Atomic原子性:      指整个数据库事务是不可分的工作单元
   Consistency一致性: 指数据库事务不能破坏关系数据的完整性以及业务逻辑上的一致性
   Isolation隔离性:   指在并发环境中, 当不同的事务同时操纵相同的数据时,每个事务都有各自的完整数据空间
   Durability持久性: 指只要事务成功结束, 它对数据库所做的更新就必须永久保存下来.
                      即使发生系统崩溃,重新启动数据库系统后,数据库还能恢复到事务成功结束时的状态.

Hibernate本身并不是数据库,它只是一个轻量级的对象-关系数据库映射(object-relational)工具。
它的事务交由底层的数据库连接管理,如果数据库连接有JTA的支持,那么在Session中进行的操作将是整个原子性JTA事务的一部分。
Hibernate可以看作是添加了面向对象语义的JDBC瘦适配器(thin adapter).


O/R Mapping: 对象/关系映射

UML diagrams <->   ER diagrams
Classes      <->   Tables
Java types    <-> SQL types

------------------
Hibernate Type: Hibernate内置映射类型

Java Type                          Hibernate Type             SQL type

java.lang.String                      string                    varchar
int | Integer                       int                       int
long | Long                        long                      bigint
short | Short                      short                     smallint
byte | Byte                       byte                      tinyint
float | Float                     float                     float
double | Double                    double                    double
java.math.BigDecimal               big_decimal               numeric
char | Character |String              character                 char(1)
boolean |Boolean                   boolean                   bit


java.util.Date |java.sql.Date         date                      date(yyyy-mm-dd)
java.util.Date |java.sql.Time         time                      time (hh:mm:ss)
java.util.Date |java.sql.Timestamp    timestamp                 timestamp(yyyymmddhhmmss)
java.util.Calender                    calender                  timestamp(yyyymmddhhmmss)
java.util.Calender                    calender_date             timestamp(yyyy-mm-dd)


byte[]                                binary                    blob|varyinary
java.lang.String                      text                      clob|text in Mysql
java.io.Serializable                  serializable              blob
java.sql.Clob                         clob                      clob|text in Mysql
java.sql.Blob                         blob                      blob     
**********************************************************************

Hibernate的对象有3种状态,分别为:瞬时态(Transient)、 持久态(Persistent)、脱管态(Detached)。处于持久态的对象也称为PO(Persistence Object),瞬时对象和脱管对象也称为VO(Value Object)。
瞬时态
        由new命令开辟内存空间的java对象,

       eg. Person person = new Person("xxx", "xx");

        如果没有变量对该对象进行引用,它将被java虚拟机回收。

         瞬时对象在内存孤立存在,它是携带信息的载体,不和数据库的数据有任何关联关系,在Hibernate中,可通过session的save()或saveOrUpdate()方法将瞬时对象与数据库相关联,并将数据对应的插入数据库中,此时该瞬时对象转变成持久化对象。

持久态
        处于该状态的对象在数据库中具有对应的记录,并拥有一个持久化标识。如果是用hibernate的delete()方法,对应的持久对象就变成瞬时对象,因数据库中的对应数据已被删除,该对象不再与数据库的记录关联。

       当一个session执行close()或clear()、evict()之后,持久对象变成脱管对象,此时持久对象会变成脱管对象,此时该对象虽然具有数据库识别值,但它已不在HIbernate持久层的管理之下。

       持久对象具有如下特点:

        1. 和session实例关联;

       2. 在数据库中有与之关联的记录。

脱管态
        当与某持久对象关联的session被关闭后,该持久对象转变为脱管对象。当脱管对象被重新关联到session上时,并再次转变成持久对象。

       脱管对象拥有数据库的识别值,可通过update()、saveOrUpdate()等方法,转变成持久对象。

       脱管对象具有如下特点:

       1. 本质上与瞬时对象相同,在没有任何变量引用它时,JVM会在适当的时候将它回收;

        2.   比瞬时对象多了一个数据库记录标识值。


hibernate的各种保存方式的区(save,persist,update,saveOrUpdte,merge,flush,lock)及 对象的三种状态
hibernate的保存
hibernate对于对象的保存提供了太多的方法,他们之间有很多不同,这里细说一下,以便区别。
一、预备知识
对于hibernate,它的对象有三种状态,transient、persistent、detached
下边是常见的翻译办法:
transient:瞬态或者自由态
(new DeptPo(1,”行政部”,20,”行政相关”),该po的实例和session没有关联,该po的实例处于transient)
persistent:持久化状态
(和数据库中记录想影射的Po实例,它的状态是persistent, 通过get和load等得到的对象都是persistent)
detached:脱管状态或者游离态
(1)当通过get或load方法得到的po对象它们都处于persistent,但如果执行delete(po)时(但不能执行事务),该po状态就处于detached, (表示和session脱离关联),因delete而变成游离态可以通过save或saveOrUpdate()变成持久态
(2)当把session关闭时,session缓存中的persistent的po对象也变成detached
因关闭session而变成游离态的可以通过lock、save、update变成持久态
持久态实例可以通过调用 delete()变成脱管状态。
通过get()或load()方法得到的实例都是持久化状态的。
脱管状态的实例可以通过调用lock()或者replicate()进行持久化。

save()和persist()将会引发SQL的INSERT,delete()会引发SQLDELETE,
而update()或merge()会引发SQL UPDATE。对持久化(persistent)实例的修改在刷新提交的时候会被检测到,它也会引起SQL UPDATE。
saveOrUpdate()或者replicate()会引发SQLINSERT或者UPDATE
二、save 和update区别
把这一对放在第一位的原因是因为这一对是最常用的。
save的作用是把一个新的对象保存
update是把一个脱管状态的对象或自由态对象(一定要和一个记录对应)更新到数据库

三、update 和saveOrUpdate区别
这个是比较好理解的,顾名思义,saveOrUpdate基本上就是合成了save和update,而update只是update;引用hibernate reference中的一段话来解释他们的使用场合和区别
通常下面的场景会使用update()或saveOrUpdate():
程序在第一个session中加载对象,接着把session关闭
该对象被传递到表现层
对象发生了一些改动
该对象被返回到业务逻辑层最终到持久层
程序创建第二session调用第二个session的update()方法持久这些改动

saveOrUpdate(po)做下面的事:
如果该po对象已经在本session中持久化了,在本session中执行saveOrUpdate不做任何事
如果savaOrUpdate(新po)与另一个与本session关联的po对象拥有相同的持久化标识(identifier),抛出一个异常
org.hibernate.NonUniqueObjectException: a different object with the same identifier value was already associated with the session: [org.itfuture.www.po.Xtyhb#5]
saveOrUpdate如果对象没有持久化标识(identifier)属性,对其调用save() ,否则update() 这个对象

四、persist和save区别
这个是最迷离的一对,表面上看起来使用哪个都行,在hibernate reference文档中也没有明确的区分他们.
这里给出一个明确的区分。(可以跟进src看一下,虽然实现步骤类似,但是还是有细微的差别)
主要内容区别:
1,persist把一个瞬态的实例持久化,但是并"不保证"标识符(identifier主键对应的属性)被立刻填入到持久化实例中,标识符的填入可能被推迟到flush的时候。

2,save, 把一个瞬态的实例持久化标识符,及时的产生,它要返回标识符,所以它会立即执行Sql insert

五、saveOrUpdate,merge和update区别
比较update和merge
update的作用上边说了,这里说一下merge的
如果session中存在相同持久化标识(identifier)的实例,用用户给出的对象覆盖session已有的持久实例
(1)当我们使用update的时候,执行完成后,会抛出异常
(2)但当我们使用merge的时候,把处理自由态的po对象A的属性copy到session当中处于持久态的po的属性中,执行完成后原来是持久状态还是持久态,而我们提供的A还是自由态

六、flush和update区别
这两个的区别好理解
update操作的是在自由态或脱管状态(因session的关闭而处于脱管状态)的对象//updateSQL
而flush是操作的在持久状态的对象。
默认情况下,一个持久状态的对象的改动(包含set容器)是不需要update的,只要你更改了对象的值,等待hibernate flush就自动更新或保存到数据库了。hibernate flush发生在以下几种情况中:
1, 调用某些查询的和手动flush(),session的关闭、SessionFactory关闭结合
get()一个对象,把对象的属性进行改变,把资源关闭。
2,transaction commit的时候(包含了flush)

七、lock和update区别
update是把一个已经更改过的脱管状态的对象变成持久状态
lock是把一个没有更改过的脱管状态的对象变成持久状态(针对的是因Session的关闭而处于脱管状态的po对象(2),不能针对因delete而处于脱管状态的po对象)
对应更改一个记录的内容,两个的操作不同:
update的操作步骤是:
(1)属性改动后的脱管的对象的修改->调用update
lock的操作步骤是:
(2)调用lock把未修改的对象从脱管状态变成持久状态-->更改持久状态的对象的内容-->等待flush或者手动flush
八、clear和evcit的区别
clear完整的清除session缓存
evcit(obj)把某个持久化对象从session的缓存中清空。

你可能感兴趣的:(sql,mysql,Hibernate,虚拟机,UML)