- 浏览: 104484 次
- 性别:
- 来自: 北京
最新评论
-
funnyone:
引用[color=darkred][/color][*][im ...
Hibernate的createSQLQuery查询的小例子 -
Bucher03:
还是看不懂啊,看不懂
如何使java中double类型不以科学计数法表示? -
scott________:
这个貌似更合适:
java.math.BigDecimal d ...
如何使java中double类型不以科学计数法表示? -
hellostory:
又是抄袭的
java.sql.Date和java.sql.Timestamp转换 -
jychenok:
对我有用,谢谢
使用window.open提交form表单
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的缓存中清空。
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的缓存中清空。
发表评论
-
s:checkboxlist 默认选中
2010-07-13 16:38 3703大家對<s:checkboxlist/>的最大的疑 ... -
去掉字符串重复值,使用符号串隔开的字符串,去掉重复的值,split
2010-06-21 15:57 1221string chongFu = "aa,bb,c ... -
MyEclipse快捷键与插件大全
2010-04-27 14:20 1668(1)Ctrl+M切换窗口的大小 (2)Ctrl+Q跳到最后 ... -
如何使java中double类型不以科学计数法表示?
2010-04-26 19:37 3895在java中,把一个double或者BigDecimal的小数 ... -
java读取txt文本,字符串截取
2010-04-02 09:35 2963package com.test; import java. ... -
Java虚拟机
2010-03-17 14:30 1150作为一种定位于网络使用的语言,Java具有许多适宜于互连网异构 ... -
整理Jsp生成html文件
2010-03-17 14:29 1305最近在用jsp生成html文件,整理出三种方法,希望对大家有所 ... -
ORACLE和SQL语法区别归纳
2010-03-04 17:16 1364数据类型比较 类型名称 Oracle SQLServe ... -
产生随机字符串(a-z A-Z 0-9)
2010-01-21 11:41 1644实现方法一: 引用 public class RandomFi ... -
SVN的安装配置 以及与MyEclipse 整合使用开发
2009-11-19 15:06 991如果你是在MyEclipse中SVN进行开发,安装下面步骤 一 ... -
svn服务器安装配置,SVN服务器使用教程,版本控制器,svn与apache整合
2009-11-19 14:41 1150一、安装SVN 1.安装svn-1. ... -
JAVA在线api
2009-11-17 18:46 1243JavaTM Platform Enterprise Edit ... -
防止刷新/后退引起的重复提交问题的Java Token代码,非Struts
2009-11-11 13:40 1767Struts本身有一套完善的防止重复提交表单的Token(令牌 ... -
MyEclipse 中的快捷键
2009-09-08 16:03 1031(1)Ctrl+M切换窗口的大 ... -
java环境变量设置
2009-09-02 10:56 1916在完成了JDK的安装后,环 ... -
如何区分处理两个提交按钮
2009-08-10 10:26 1842一个FORM表单中有两个SUBMIT按钮(例如“修改”“删除” ... -
Hibernate的createSQLQuery查询的小例子
2009-08-03 15:28 4059今天用createSQLQuery 查询 ,当查询部门(人事 ... -
java.math.BigDecimal的精度问题
2009-08-03 10:58 12751. String myMoney = "100 ... -
struts2中select标签的使用
2009-07-30 19:10 1243struts2的select标签中,常用的有以下几个属性: ... -
Hibernate hql查询
2009-07-20 16:16 11351、 实体查询: 有关实 ...
相关推荐
Hibernate 是一个流行的 Java 开发框架,用于简化数据库...理解 Hibernate 对象状态及其转换对于有效管理和优化数据库操作至关重要。正确使用这些状态和保存方法能够避免数据冗余和丢失,提高应用的性能和数据一致性。
在Java的持久化框架Hibernate中...正确管理对象状态可以帮助优化数据库交互,减少不必要的查询,提高系统的整体性能。在实际开发中,开发者需要根据业务需求和性能考虑,灵活运用这些状态,确保数据的一致性和完整性。
Java面试题57.hibernate对象状态及其转换.mp4
java工程师
Hibernate 对象状态之间的神奇转换 Hibernate 框架中对象状态之间的转换是非常重要的概念,它们之间的转换关系非常复杂。本文将详细介绍 Hibernate 对象状态之间的神奇转换,包括瞬时态、持久态、脱管态 ثلاث种...
在处理大量数据或复杂的业务逻辑时,正确地使用Hibernate对象状态可以极大地提高效率和性能。例如,当处理大量对象时,可以先将对象设置为游离状态,待所有更改完成后再一次性提交,以减少数据库事务的频繁交互。
理解Hibernate对象状态对于优化应用性能至关重要,例如,正确地管理Session的生命周期可以减少不必要的数据库交互,提高效率。在处理大量数据时,避免在事务中保留大量持久态对象,可以防止内存溢出。而合理使用脱管...
在Java的持久化框架Hibernate中,对象存在三种不同的状态,分别是持久态(Persistent)、自由态(Transient)和游离态(Detached)。这三种状态分别对应了对象与数据库的关联程度,理解它们对于高效地使用Hibernate...
hibernate中session对象的状态详解
同时,文档《Hibernate对象状态及一对多关联.doc》详细介绍了如何设置和管理一对多关联,这种关联在企业级应用中非常常见,例如一个用户可以有多个订单。 2. **一对一和多对多关联** 在《Hiberate一对一和多对多...
一、Hibernate对象三状态 1. 游离态(Detached):对象在应用程序中创建,但尚未与Session关联。对象的状态和数据库中的记录可能不一致。 2. 瞬时态(Transient):对象刚被创建,与Session关联,但尚未持久化到...
本人在厦门邦初培训时候 使用的快速入门精简文档 ...对象的临时状态、持久状态和游离状态 用session的update()方法使游离对象转变为持久化对象。 延迟装载 迫切左外链接 HQL检索方式 QBC检索方式 本地SQL检索方式
在 Hibernate 框架中,Java 对象的状态管理和 Session 缓存是核心概念,它们直接影响着数据的持久化过程和数据库...同时,根据具体应用需求,选择合适的缓存清理策略和对象状态转换时机,以达到最佳的数据库操作效果。
4. Hibernate对象状态: Hibernate将对象分为四种状态:瞬时态、持久态、托管态和游离态,理解这些状态对于正确使用Hibernate至关重要。 5. Hibernate映射机制: 使用XML或注解来定义对象和表之间的映射关系,...
五、Hibernate对象状态 Hibernate将对象分为四种状态:瞬时态、持久态、托管态和脱管态。理解这些状态及其转换对于正确使用Hibernate至关重要。 六、查询语言HQL与 Criteria API HQL(Hibernate Query Language)是...
3. Hibernate对象状态: Hibernate中的对象有三种状态: - **瞬时态(Transient)**:对象在内存中创建,但尚未与数据库关联。使用`session.save()`或`saveOrUpdate()`方法可以将瞬时对象转化为持久态。 - **持久态...
Session提供了事务管理和缓存功能,确保了对象状态的正确管理。例如,一级缓存(First Level Cache)自动管理持久态对象,而二级缓存(Second Level Cache)则可跨Session共享数据,提高性能。 6. HQL与 Criteria ...
#### Hibernate 对象状态 Hibernate 支持对象的多种状态管理,包括瞬时状态(Transient)、持久状态(Persistent)和游离状态(Detached),每种状态对应不同的行为。 #### HQL 和 Native SQL - **HQL**(Hibernate...
- **Hibernate对象状态**: 介绍了瞬态、持久、游离等状态。 - **使对象持久**: 如何将对象变为持久状态。 - **加载一个对象**: 使用不同的方法加载持久化对象。 - **查询**: 使用HQL或其他查询语言执行复杂查询。
Hibernate对象状态 对象在Hibernate中有以下几种状态: - **瞬时态(Transient)**:对象刚刚被创建,还没有与Session关联,没有持久化标识符(ID)。如果对象在这个状态下被垃圾回收,那么所有关于该对象的数据...