hibernateTemplate调用存储过程
来源:互联网 发布:php和mysql web开发pdf 编辑:程序博客网 时间:2024/05/16 01:20
第一种
-----------------------------------------------------------------------
CallableStatement cstmt = hibernateTemplate.getSessionFactory().getCurrentSession().connection().prepareCall("{call collin000.updateDepart}");
cstmt.executeUpdate();
------------------------------------------------------------------------
第二种
------------------------------------------------------------------------
hibernateTemplate.execute(
new HibernateCallback()
{
public Object doInHibernate(Session session) throws SQLException
{
CallableStatement cs = session.connection().prepareCall("{call collin000.updateDepart}");
cs.executeUpdate();
return null;
}
}
);
-----------------------------------------------------------------------------------------------
Hibernate的复杂用法HibernateCallback
HibernateTemplate提供一种灵活的方式来操作数据库,通过这种方式可以完全使用Hibernate的操作方式。HibernateTemplate的灵活访问方式是通过如下两个方法完成:
Object execute(HibernateCallback action)
List execute(HibernateCallback action)
这两个方法都需要一个HibernateCallback的实例,HibernateCallback实例可在任何有效的Hibernate数据访问中使用。程序开发者通过HibernateCallback,可以完全使用Hibernate灵活的方式来访问数据库,解决Spring封装Hibernate后灵活性不足的缺陷。HibernateCallback是一个接口,该接口只有一个方法doInHibernate(org.hibernate.Session session),该方法只有一个参数Session。
通常,程序中采用实现HibernateCallback的匿名内部类来获取HibernateCallback的实例,方法doInHibernate的方法体就是Spring执行的持久化操作。具体代码如下:
- public class PersonDaoImpl implements PersonDao
- {
- //私有实例变量保存SessionFactory
- private SessionFactory sessionFactory;
- //依赖注入必须的setter方法
- public void setSessionFactory(SessionFactory sessionFactory)
- {
- this.sessionFactory = sessionFactory;
- }
- /**
- * 通过人名查找所有匹配该名的Person实例
- * @param name 匹配的人名
- * @return 匹配该任命的全部Person集合
- */
- public List findPersonsByName(final String name)
- {
- //创建HibernateTemplate实例
- HibernateTemplate hibernateTemplate =
- new HibernateTemplate(this.sessionFactory);
- //返回HibernateTemplate的execute的结果
- return (List) hibernateTemplate.execute(
- //创建匿名内部类
- new HibernateCallback()
- {
- public Object doInHibernate(Session session) throws HibernateException
- {
- //使用条件查询的方法返回
- List result = session.createCriteria(Person.class)
- .add(Restrictions.like(“name”, name+”%”)
- .list();
- return result;
- }
- });
- }
- }
注意:方法doInHibernate方法内可以访问Session,该Session对象是绑定到该线程的Session实例。该方法内的持久层操作,与不使用Spring时的持久层操作完全相同。这保证对于复杂的持久层访问,依然可以使用Hibernate的访问方式。
- HIbernateTemplate调用存储过程
- hibernateTemplate调用存储过程
- spring HibernateTemplate调用存储过程
- spring HibernateTemplate调用存储过程
- hibernateTemplate执行存储过程
- 存储过程调用存储过程
- Ibatis调用存储过程调用存储过程
- Java调用存储过程
- 存储过程调用
- asp调用存储过程!
- Asp调用存储过程
- Java 调用存储过程
- Java 调用存储过程
- asp调用存储过程
- JAVA调用存储过程
- cognos调用存储过程
- asp调用存储过程
- 存储过程调用com
- 觉得写的有道理,转一下:闲暇中自我成长
- 2014年4月操作系统份额:Windows XP仍然在26%以上,Linux微涨
- 关于ehcache,memcache,redis的优势比较
- android AsyncTask
- nodejs request设置proxy
- hibernateTemplate调用存储过程
- hudson配置说明
- LR模拟HLS协议
- AssertionError、Error和Throwable
- When to use awakeFromNib , initWithWindow , windowDidLoad methods?
- 解决CentOS配置kdump失败的问题
- JAVA中String类的常用功能
- CSS定位之绝对定位
- SELinux中的sesearch命令找不到