Session接口的API
Method Summary | |
beginTransaction() | |
void | cancelQuery() |
void | clear() |
close() | |
connection() 关闭这个调用的连接的职责应该由当前应用程序负责。 | |
boolean | contains(Object object) |
createCriteria(Class persistentClass) | |
createCriteria(Class persistentClass, String alias) | |
createCriteria(String entityName) | |
createCriteria(String entityName, String alias) | |
createFilter(Object collection, String queryString) | |
createQuery(String queryString) | |
createSQLQuery(String queryString) | |
void | |
void | delete(String entityName, Object object) |
void | disableFilter(String filterName) |
disconnect() | |
enableFilter(String filterName) | |
void | |
void | flush() |
get(Class clazz, Serializable id) | |
get(Class clazz, Serializable id, LockMode lockMode) | |
get(String entityName, Serializable id) | |
get(String entityName, Serializable id, LockMode lockMode) | |
getCacheMode() | |
getCurrentLockMode(Object object) | |
getEnabledFilter(String filterName) | |
getEntityMode() | |
getEntityName(Object object) | |
getFlushMode() | |
getIdentifier(Object object) 如果该实例是自由状态(Transient)的或者与其它Session关联则抛出一个异常。 | |
getNamedQuery(String queryName) | |
getSession(EntityMode entityMode) | |
getSessionFactory() | |
getStatistics() | |
getTransaction() | |
boolean | isConnected() |
boolean | isDirty() 如果我们刷新提交(flush)这个session是否会有SQL执行? |
boolean | isOpen() |
load(Class theClass, Serializable id) | |
load(Class theClass, Serializable id, LockMode lockMode) | |
void | load(Object object, Serializable id) |
load(String entityName, Serializable id) | |
load(String entityName, Serializable id, LockMode lockMode) | |
void | |
void | lock(String entityName, Object object, LockMode lockMode) |
merge(String entityName, Object object) | |
void | |
void | persist(String entityName, Object object) |
void | reconnect() 在这种情况下或许应该使用reconnect(java.sql.Connection)。 |
void | reconnect(Connection connection) |
void | |
void | refresh(Object object, LockMode lockMode) |
void | replicate(Object object, ReplicationMode replicationMode) |
void | replicate(String entityName, Object object,ReplicationMode replicationMode) |
save(Object object) | |
save(String entityName, Object object) | |
void | saveOrUpdate(Object object) |
void | saveOrUpdate(String entityName, Object object) |
void | setCacheMode(CacheMode cacheMode) |
void | setFlushMode(FlushMode flushMode) |
void | setReadOnly(Object entity, boolean readOnly) |
void | |
void | update(String entityName, Object object) |
Java应用程序与Hibernate之间的主要运行时接口。它是抽象了持久化服务概念的核心抽象API类。
Session的生命周期绑定在一个物理的事务(tansaction)上面。(长的事务可能跨越多个数据库事物。)
Session的主要功能是提供对映射的实体类实例的创建,读取和删除操作。实例可能以下面三种状态存在:
自由状态(transient): 不曾进行持久化,未与任何Session相关联
持久化状态(persistent): 仅与一个Session相关联
游离状态(detached): 已经进行过持久化,但当前未与任何Session相关联
游离状态的实例可以通过调用save()、persist()或者saveOrUpdate()方法进行持久化。持久化实例可以通过调用 delete()变成游离状态。
通过get()或load()方法得到的实例都是持久化状态的。游离状态的实例可以通过调用 update()、0saveOrUpdate()、lock()或者replicate()进行持久化。
游离或者自由状态下的实例可以通过调用merge()方法成为一个新的持久化实例。
save()和persist()将会引发SQL的INSERT,delete()会引发SQLDELETE,而update()或merge()会引发SQLUPDATE。
对持久化(persistent)实例的修改在刷新提交的时候会被检测到,它也会引起SQLUPDATE。
saveOrUpdate()或者replicate()会引发SQLINSERT或者UPDATE。
其具体实现并不一定是线程安全的。每个线程/事务应该从一个SessionFactory获取自己的session实例。
如果其持久化对象类是可序列化的,则Session实例也是可序列化的。
一个典型的事务应该使用下面的形式:
Session sess = factory.openSession();
Transaction tx;
try {
tx =sess.beginTransaction();
//do some work ...
tx.commit();
} catch (Exception e) {
if (tx!=null)
tx.rollback();
throw e;
} finally {
sess.close();
}
如果Session抛出了异常, 事务必须回滚而session会被废弃。在异常发生后Session的内部状态可能会与数据库失去同步。
Session接口
Session接口是Java应用程序和Hibernate进行交互时所使用的主要接口, 这也是持久化操作的核心API。Session对象是有生命周期的,
它以Transaction对象的事务开始和结束为边界。Session对象不是线程安全的,每个调用者应该使用SessionFactory实例获得组件的Session实例。
Session主要的功能是读取、创建和删除映射对象的实例,这一系列的操作将被转换为对数据库表中的增加、修改、查询和删除操作。
创建Session实例可以采用以下代码来实现:
Configuration cof=newConfiguration().config();
SessionFactorysessionFactory=cof.buildSessionFactory();
Session session=sessionFactory.openSession();
1、Session的save()/persist()/update()/saveOrUpdate()/merge()/delete()方法
save()方法将指定对象保存,插入表中一条数据;
update()方法将指定对象更新,更新表中一条数据;
saveOrUpdate()方法接收一个实体对象,根据实体对象的id判断是否已经存在进行保存或更新操作,这样保存和更新方法就统一了;
merge()方法将给定的对象的状态复制到具有相同标识的持久化对象上。
delete()方法将指定对象删除,删除表中一条数据;
特别注意:为了使用saveOrUpdate()方法,在由定义映射文件时,通过设定<id>标签的unsaved-value="null"来判断执行什么操作:
当id属性等于unsaved-value的值(在此为null)时,则认为还没有保存,应该执行保存操作,否则执行更新操作。
这样设定之后,可以使用saveOrUpdate()方法来统一保存和更新的方法。
<id name="id" column="id"type="java.lang.Integer" unsaved-value="null">
<generator class="native"/>
</id>
unsaved-value可以设定的值有四个:
any:总是储存
none:总是更新
null:id为null时储存(预设)
valid:id为null或是指定值时储存
2、Session的get()/load()方法
get()方法会总是查询实体对象,不存在时候返回null;
load()方法也是获取一个实体对象,不存在时候抛空指针异常。
3、Session的clear()/evict()方法
clear()方法清除Session级别缓存中的所有实体(包括各种状态)对象,目的是释放内存。
evict()方法清除Session级别缓存中的指定的实体(包括各种状态)对象。
Session关闭后,这些缓存也就不存在了,会等待JVM回收。
4、Session的flush()方法
flush()强制持久化Session缓存中的实体对象。一般还会调用clear()或evict(),目的是赶紧保存,释放宝贵内存资源。
5、Session的commit()/rollback()方法
commit()方法用于提交Session上的事务,否则工作单元不会对数据库产生影响。
如果执行出现异常(也就是commit()失败了),则之前的操作取消,执行rollback()可撤消之前的操作。
6、Session的close()/isOpen()/isConnected()/reconnect()方法
close()方法关闭Session所对应数据库连接,与其相关联的对象生命周期结束。
isOpen()方法检查Session是否仍然打开,如果Session已经断开,则可以使用reconnect(Connection connection)来重新让Session关联一个JDBC连接。
isConnected()方法检查当前Session是否处于连接状态。