HibernateTemplate、HibernateDaoSupport两种方法实现增删改查Good


首先,定义一个Customer的bean类,设置好Customer.hbm.xml文件。再定义好一个Dao接口。准备好一个jdbc.properties文件。

第一种方法:

在dao类中定义一个HibernateTemplate类的对象,用该对象调用HibernateTemplate模板封装好的方法,如下:


  1. /*** 
  2.  * hibernateTemplate的转配模式 
  3.  */  
  4. public class CustomerDaoImpl implements CustomerDao {  
  5.     // 设置hibernateTemplate属性  
  6.     private HibernateTemplate hibernateTemplate;  
  7.   
  8.     // 必须设置set方法  
  9.     public void setHibernateTemplate(HibernateTemplate hibernateTemplate) {  
  10.         this.hibernateTemplate = hibernateTemplate;  
  11.     }  
  12.   
  13.     // 插入方法  
  14.     @Override  
  15.     public void insert(Customer entity) {  
  16.         hibernateTemplate.save(entity);  
  17.     }  
  18.   
  19.     // 删除方法(按照试题删除)  
  20.     @Override  
  21.     public void delete(Customer entity) {  
  22.         hibernateTemplate.delete(entity);  
  23.   
  24.     }  
  25.   
  26.     // 删除方法,按id删除,该方法不成功  
  27.     @Override  
  28.     public void deleteById(int id) {  
  29.         // hibernateTemplate.  
  30.     }  
  31.   
  32.     // 查询所有记录  
  33.     @Override  
  34.     public List<Customer> selectAll() {  
  35.         // TODO Auto-generated method stub  
  36.         List<Customer> entities = hibernateTemplate.find("from Customer");  
  37.         return entities;  
  38.     }  
  39.   
  40.     // 按照id查找记录  
  41.     @Override  
  42.     public Customer selectById(int id) {  
  43.         // TODO Auto-generated method stub  
  44.         List<Customer> entitise = hibernateTemplate  
  45.                 .find("from Customer where id=" + id);  
  46.         if (entitise.size() > 0) {  
  47.             Customer entity = entitise.get(0);  
  48.             return entity;  
  49.         }  
  50.         return null;  
  51.     }  
  52.   
  53.     // 更新方法  
  54.     @Override  
  55.     public void update(Customer entity) {  
  56.         // TODO Auto-generated method stub  
  57.         hibernateTemplate.update(entity);  
  58.     }  
  59.   




xml中的部分代码如下:


    <!-- 分散配置 -->  
        <context:property-placeholder location="jdbc.properties" />  
      
        <!-- c3p0数据源 -->  
        <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">  
            <!-- 驱动程序 -->  
            <property name="driverClass">  
                <value>${jdbc.driverClass}</value>  
            </property>  
      
            <!-- 连接的url地址 -->  
            <property name="jdbcUrl">  
                <value>${jdbc.url}</value>  
            </property>  
      
            <!-- 连接的用户名 -->  
            <property name="user">  
                <value>${jdbc.user}</value>  
            </property>  
      
            <!-- 连接的密码 -->  
            <property name="password">  
                <value>${jdbc.password}</value>  
            </property>  
      
            <!-- 最大池数 -->  
            <property name="maxPoolSize">  
                <value>${c3p0.pool.max}</value>  
            </property>  
      
            <!-- 最小池数 -->  
            <property name="minPoolSize">  
                <value>${c3p0.pool.min}</value>  
            </property>  
            <!-- 默认初始化的池数 -->  
            <property name="initialPoolSize">  
                <value>${c3p0.pool.init}</value>  
            </property>  
        </bean>  
      
      
        <bean id="sessionFactory"  
            class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">  
            <!-- 设置数据源 -->  
            <property name="dataSource" ref="dataSource" />  
            <!-- 属性设置 -->  
            <property name="hibernateProperties">  
                <props>  
                    <prop key="hibernate.show_sql">${hibernate.show_sql}</prop>  
                    <prop key="hibernate.hbm2ddl.auto">${hibernate.hbm2ddl.auto}</prop>  
                </props>  
            </property>  
            <!-- 映射文件配置 -->  
            <property name="mappingResources">  
                <list>  
                    <value>cn/csdn/domain/Customer.hbm.xml</value>  
                </list>  
            </property>  
      
        </bean>  
      
      
        <span style="background-color: #ff0000;"><!-- hibernate模板 -->  
        <bean id="hibernateTemplate" class="org.springframework.orm.hibernate3.HibernateTemplate">  
            <property name="sessionFactory" ref="sessionFactory" />  
        </bean></span>  
      
        <!-- dao的操作的bean -->  
        <bean id="customerDaoImpl" class="cn.csdn.dao.CustomerDaoImpl">  
            <!-- 注入依赖模板 -->  
            <property name="hibernateTemplate" ref="hibernateTemplate" />  
            </bean>  

第二种方法:

Dao实现类继承HibernateDaoSupport类,该类是抽象类,该类中有一个HibernateTemplate的属性,通过this.getHibernateTemplate()可获得一个HibernateTemplate类的对象。

Dao实现类中的代码如下:


    /** 
     * 继承HibernateDaoSupport类,HibernateDaoSupport类中封装了一个hibernateTemplate变量 
     */  
    public class CustomerDaoImpl1 extends HibernateDaoSupport implements  
            CustomerDao {  
      
        // 添加记录  
        @Override  
        public void insert(Customer entity) {  
            this.getHibernateTemplate().save(entity);  
        }  
      
        // 删除记录(按照实体删除)  
        @Override  
        public void delete(Customer entity) {  
            // TODO Auto-generated method stub  
            this.getHibernateTemplate().delete(entity);  
      
        }  
      
        // 删除记录(按id删除),不成功  
        //  
        @Override  
        public void deleteById(int id) {  
            // TODO Auto-generated method stub  
            // this.getHibernateTemplate().delete(entity);  
        }  
      
        // 查询所有的记录  
        @Override  
        public List<Customer> selectAll() {  
            // TODO Auto-generated method stub  
            List<Customer> entities = this.getHibernateTemplate().find(  
                    "from Customer");  
            return entities;  
        }  
      
    //  按照id查找记录  
        @Override  
        public Customer selectById(int id) {  
            // TODO Auto-generated method stub  
            List<Customer> entities=this.getHibernateTemplate().find("from Customer where id="+id);  
            if(entities.size()>0){  
                Customer entity=entities.get(0);  
                return entity;  
            }  
            return null;  
        }  
      
    //  更新的方法  
        @Override  
        public void update(Customer entity) {  
            // TODO Auto-generated method stub  
            this.getHibernateTemplate().update(entity);  
        }  
      
        }  


xml中的部分代码:


<!-- 分散配置 -->  
    <context:property-placeholder location="jdbc.properties" />  
  
    <!-- c3p0数据源 -->  
    <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">  
        <!-- 驱动程序 -->  
        <property name="driverClass">  
            <value>${jdbc.driverClass}</value>  
        </property>  
  
        <!-- 连接的url地址 -->  
        <property name="jdbcUrl">  
            <value>${jdbc.url}</value>  
        </property>  
  
        <!-- 连接的用户名 -->  
        <property name="user">  
            <value>${jdbc.user}</value>  
        </property>  
  
        <!-- 连接的密码 -->  
        <property name="password">  
            <value>${jdbc.password}</value>  
        </property>  
  
        <!-- 最大池数 -->  
        <property name="maxPoolSize">  
            <value>${c3p0.pool.max}</value>  
        </property>  
  
        <!-- 最小池数 -->  
        <property name="minPoolSize">  
            <value>${c3p0.pool.min}</value>  
        </property>  
        <!-- 默认初始化的池数 -->  
        <property name="initialPoolSize">  
            <value>${c3p0.pool.init}</value>  
        </property>  
    </bean>  
  
  
    <bean id="sessionFactory"  
        class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">  
        <!-- 设置数据源 -->  
        <property name="dataSource" ref="dataSource" />  
        <!-- 属性设置 -->  
        <property name="hibernateProperties">  
            <props>  
                <prop key="hibernate.show_sql">${hibernate.show_sql}</prop>  
                <prop key="hibernate.hbm2ddl.auto">${hibernate.hbm2ddl.auto}</prop>  
            </props>  
        </property>  
        <!-- 映射文件配置 -->  
        <property name="mappingResources">  
            <list>  
                <value>cn/csdn/domain/Customer.hbm.xml</value>  
            </list>  
        </property>  
  
    </bean>  
  
  
    <!-- 设置HibernateDaoSupport抽象类-->  
    <bean id="hibernateDaoSupport"  
        class="org.springframework.orm.hibernate3.support.HibernateDaoSupport"  
        abstract="true">  
        <property name="sessionFactory" ref="sessionFactory" />  
    </bean> 

    <!-- dao的操作的bean -->  
    <bean id="customerDaoImpl" class="cn.csdn.dao.CustomerDaoImpl1"  
            parent="hibernateDaoSupport" /> 
     <bean id="adminDAO" class="com.haier.uhome.hr91.manager.dao.AdminDAO">
             parent="hibernateDaoSupport"/>
或者如下

<bean id="customerDaoImpl" class="cn.csdn.dao.CustomerDaoImpl1">
        <property name="sessionFactory">
            <ref local="sessionFactory" />
        </property>
    </bean>

<bean id="adminDAO" class="com.haier.uhome.hr91.manager.dao.AdminDAO">
        <property name="sessionFactory">
            <ref local="sessionFactory" />
        </property>
    </bean>






转自 :http://blog.csdn.net/baple/article/details/23352059



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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值