SSH之继承HibernateDaoSupport对数据库的操作和不继承HibernateDaoSupport对数据库的操作的方法
来源:互联网 发布:农村淘宝的运营模式 编辑:程序博客网 时间:2024/05/16 06:28
在使用ssh来开发项目的时候,我们都希望spring来管理事务,进而管理dao层,增加开发效率,有利于快速实现功能,少出现错误。
如果需要在dao层访问数据库,可以采用在dao层的类继承HibernateDaoSupport。需要注意的是:
1.当继承了该类以后必须让spring对其进行管理。否则在该类中使用类似getSession将会报错。因为无法获得session工厂。在该类里面有了getHibernateTemplate和setSessionFactory方法,且是final的.我们就应该把SessionFactory到该HibernateDaoSupport中。
错误:在spring的配置文件中:写了sessionFactory的bean之后,继承HibernateDAOSupport,发现会报错,说"sessionFactory " or "hibernateTemplate " is required。。。
原因在于,spring没有能将我们在配置文件中写的bean注入到HibernateDAOSupport中,因为spring默认情况下是不会自动装配的。
使用情况:
1.在上面情况做好以后,我们得到session就十分的方便了。如:
String hql = "update User u set ......";....
Query query = getSession.createQuery(hql);
query.excuteUpdate();
2.我们还可以使用getHibernate来对数据库进行操作
配置文件:<bean name="userDAO" class="com.msb.dao.UserDAOImpl">
<property name="sessionFactory" ref="mySessionFactory"></property>
</bean>
Dao层:public class UserDAOImpl extends HibernateDaoSupport implements UserDAO{
public void save(User user){
this.getHibernateTemplate().save(user);
}
}
其他方法:
void delete(Object entity)删除指定持久化实例
deleteAll(Collection entities)删除集合内全部持久化实例
find(String queryString)根据HQL查询字符串返回实例集合
findByNamedQuery(Striing QueryName)根据命名查询返回实例集合
Get(Class entityClass,Serializable id)割据主键加载特定持久化类的实例
save(Object entity)保存实例
saveOrUpdate(Object entity)根据实例状态,选择保存或者更新
update(Object entity)更新实例的状态
setMaxResults(int maxResults)设置分页大小
3.Hibernate的复杂用法HibernateCallback HibernateTemplate还提供一种更加灵活的方式来操作数据库,通过这种方式可以完全使用Hibernate的操作方式。
HibernateTemplate的灵活访问方式是通过如下两个方法完成:
(1)Object execute(HibernateCallback action)
(2)List execute(HibernateCallback action)
这两个方法都需要一个HibernateCallback的实例,HibernateCallback实例可在任何有效的Hibernate数据访问中使用。
程序开发者通过HibernateCallback,可以完全使用Hibernate灵活的方式来访问数据库,解决Spring封装Hibernate后灵活性不足的缺陷。
HibernateCallback是一个接口,该接口只有一个方法doInHibernate(org.hibernate.Session session),
该方法只有一个参数Session。通常,程序中采用实现HibernateCallback的匿名内部类来获取HibernateCallback的实例,
方法doInHibernate的方法体就是Spring执行的持久化操作。
List<Account> KFGLList = getHibernateTemplate().executeFind(new HibernateCallback() {
@Override
public Object doInHibernate(Session session)
throws HibernateException, SQLException {
Query query = session.createQuery(hql);
List<String> KFGLList = query.list();
return KFGLList;
}
});
最后
如果不继承HibernateDaoSupport如何实现增删查改呢。换句话说如何获得hibernateTemplate对象呢,其实简单。直接通过属性注入。
1. 在目标类(XXXDaoImpl)中写出属性
private HibernateTemplate hibernateTemplate;
省略set get 方法...
在配置文件中配置:
<bean name="hibernateTemplate" class="org.springframework.orm.hibernate3.HibernateTemplate">
<property name="sessionFactory" ref="sessionFactory"/>
</bean>
然后
<bean name="XXXDaoImpl" class="xxxx.xxxx.xxxx.XXXDaoImpl">
<property name="hibernateTemplate" ref="hibernateTemplate">
</bean>
这样就把hibernateTemplate注入到目标类中了。
- SSH之继承HibernateDaoSupport对数据库的操作和不继承HibernateDaoSupport对数据库的操作的方法
- SSH中继承HibernateDaoSupport 的通用Dao
- SSH的一个BaseDao继承HibernateDaoSupport(一)
- SSH的一个BaseDao继承HibernateDaoSupport(二)
- 继承 HibernateDaoSupport 的getSession 问题
- 继承了HibernateDaoSupport的DAO
- 继承HibernateDaoSupport后,获得session 并使用session操作sql的方法
- Hibernate数据库访问 之 继承HibernateDaoSupport类
- Spring中使用HibernateDaoSupport来进行数据库的操作
- 继承HibernateDaoSupport进行CURD操作
- SSH中daoImpl类继承HibernateDaoSupport的用法
- 配置DataSource方法(BasicDataSource为例) 和 具体的数据库操作(HibernateDaoSupport、HibernateTemplate和jdbcTemplate)
- ssh中dao继承HibernateDaoSupport类实现模板操作
- 继承HibernateDaoSupport引发的错误总结,spring对hibernate的集成
- 继承HibernateDaoSupport时遇到的问题
- 关于DAO层的sessionFactory注入和是否继承HibernateDAOSupport
- ssh整合之HibernateDaoSupport的使用
- 对数据库的操作
- unity----脚本入门
- Apache2.4.4服务器配置文件httpd.conf的主要结构注释
- 将mysql数据库转换到oracle的工具
- Anagrams
- iOS中的内存管理
- SSH之继承HibernateDaoSupport对数据库的操作和不继承HibernateDaoSupport对数据库的操作的方法
- JavaScript面向对象编程(10)快速构建继承关系之对象拷贝
- unity--脚本入门
- [docker]docker的四种网络方式
- 使用VIM阅读代码
- 春天JDBC事务管理
- 链栈,C++,数据结构王红梅版
- 序列化与反序列化
- 春天的事务管理,图解事务传播行为