Hibernate session的方法的一些说明

用Hibernate肯定会频繁的用到session,下面就将session中一些经常的用方法逐个的解释一下

 

 

Transaction beginTransaction()

    开始一个工作单元并返回一个与之相关Transaction对象,最为事务的开始,通常在需要对数据库进行更改例如save,update或delete时使用。在事务结束后需要调用Transaction的commit方法提交更改,该方法必须在session关闭之前使用。

 

 

void flush() void clear()

    这两个方法通常在一起使用。由于Hibernate有缓存数据的功能,所以当我们要批量查询和批量插入时,会因为大量的缓存而导致内存溢出。所以我们可以在执行批量插入时插入一定数目的数据后调用flush()提交插入,然后调用clear()清空当前session内的所有缓存。批量查询同理

 

 

Connection close()

    关闭session,同时清空所有的缓存。

 

 

Connection connection()

    获取当前session使用的JDBC connection。

 

 

boolean contains(Object object)

    返回boolean值,判断一个实例是否与当前session保持关联,即为持久化状态。

 

 

Query createQuery(String queryString)

    返回一个给定HQL语句的Query对象。

 

 

SQLQuery createSQLQuery(String queryString)

    返回一个用于执行原生SQL语句的SQLQuery对象

 

 

void delete(Object object)

    删除与该对象关联的数据里内的一条记录。该对象可以是处于持久化状态也可以是处于瞬态但与数据库的记录有id联系。如果该对象的cascade属性为delete或all将会同时删除相关联的数据。

 

 

void delete(String entityName, Object object)

    不太明白什么意思,占个位。

 

 

Connection disconnect()

    断开与session与当前JDBC的连接,如果连接有Hibernate管理,则将连接送回连接池,否则将送回给程序本身。

 

 

Object get(Class clazz, Serializable id)

    根据指定的实体类以及实体id返回一个实体的实例。如果找不到记录则返回null

 

 

Object get(String entityName, Serializable id)

    同上,entity为实体的名字

 

 

String getEntityName(Object object)

    返回一个持久化类的实体名

 

 

Serializable getIdentifier(Object object)

    返回一个被session缓存的实体实例的id

 

 

Query getNamedQuery(String queryName)

    返回一个在映射文件中定义的命名查询的query对象

 

 

SessionFactory getSessionFactory()

    获取生成当前session的SessionFactory

 

 

Transaction getTransaction()

    不说了,地球人都知道

 

 

Object load(Class theClass, Serializable id)

Object load(String entityName, Serializable id)

    和get方法一个效果,不同的是该方法在找不到对应记录时会抛出异常

 

 

Serializable save(Object object)

    将一个实体实例持久化,返回该持久化实例的id。在持久化之前必须手动或自动的指派id。

 

 

void update(Object object)

    通过给定的分离状态的实例的id更新数据库记录。如果在持久化类中有相同的id则会抛出异常。如果这个实例cascade设置为save-update或all是将同时更新所有关联的实例记录。

 

 

void saveOrUpdate(Object object)


本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/zhiweiv/archive/2008/09/23/2969730.aspx

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值