SSH与SSM学习之SSH整合08——Spring整合Hibernate环境操作数据库

SSH与SSM学习之SSH整合08——Spring整合Hibernate环境操作数据库

一、整合说明

这里整合其实主要就是 DAO 的操作。DAO操作的时候,我们可以有两种方式的操作。

第一种 就是我们像平时一样创建一个DAO的实现类,包含一个 HibernateTemplate 的对象,

在Spring中配置的时候,注入 HibernateTemplate 的实例。当然 HibernateTemplate 中

包含了一个 SessionFactory 的对象,我们也需要自己出入,这样就需要注入两步。

第二种 就是我们像平时一样创建一个DAO的实现类,并且让它继承自 HibernateDaoSupport

在Spring中配置的时候,我们只需要注入 SessionFactory 就行了。

下面我们使用的是第二种。


二、UserDao

2.1 UserDao

package com.qwm.ssh_crm.dao;

import com.qwm.ssh_crm.domain.User;

/**
 * @author:qiwenming
 * @date:2017/11/4 0004   17:24
 * @description:
 */
public interface UserDao {
    //根据登陆名称查询user对象
    User getByUserCode(String usercode);
    //保存用户
    void save(User u);
}

2.2 UserDaoImpl

package com.qwm.ssh_crm.dao.impl;

import com.qwm.ssh_crm.dao.UserDao;
import com.qwm.ssh_crm.domain.User;
import org.hibernate.HibernateException;
import org.hibernate.Session;
import org.hibernate.criterion.DetachedCriteria;
import org.hibernate.criterion.Restrictions;
import org.hibernate.query.Query;
import org.springframework.orm.hibernate5.HibernateCallback;
import org.springframework.orm.hibernate5.support.HibernateDaoSupport;

import java.util.List;

/**
 * @author:qiwenming
 * @date:2017/11/4 0004   17:25
 * @description:
 */
public class UserDaoImpl extends HibernateDaoSupport implements UserDao{
//    @Override
//    public User getByUserCode(String usercode) {
//        //HQL方式查询
//        return getHibernateTemplate().execute(new HibernateCallback<User>() {
//            @Override
//            public User doInHibernate(Session session) throws HibernateException {
//                String sql = "from User where user_code=?";
//                Query query = session.createQuery(sql);
//                query.setParameter(0,usercode);
//                User user = (User)query.uniqueResult();
//                return user;
//            }
//        });
//    }

    @Override
    public User getByUserCode(String usercode) {
        //Criteria 方式查询
        //是一个离线 Criteria
        DetachedCriteria dc = DetachedCriteria.forClass(User.class);
        dc.add(Restrictions.eq("user_code",usercode));
        List<User> list = (List<User>) getHibernateTemplate().findByCriteria(dc);
        if(list!=null && list.size()>0)
            return list.get(0);
        return null;
    }

    @Override
    public void save(User u) {
        getHibernateTemplate().save(u);
    }
}

三、Spring中配置

最主要的配置

   <!--dao配置-->
    <bean name="userDao" class="com.qwm.ssh_crm.dao.impl.UserDaoImpl">
        <property name="sessionFactory" ref="sessionFactory"/>
    </bean>

完整的 applicationContext.xml配置

<?xml version="1.0" encoding="UTF-8" ?>
<beans xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns="http://www.springframework.org/schema/beans"
       xmlns:context="http://www.springframework.org/schema/context"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
            http://www.springframework.org/schema/beans/spring-beans-4.3.xsd
            http://www.springframework.org/schema/context
            http://www.springframework.org/schema/context/spring-context-4.3.xsd ">

    <!--Action配置 手动组装依赖  必须配置为多例模式-->
    <bean name="userAction" class="com.qwm.ssh_crm.web.action.UserAction" scope="prototype">
        <property name="userService" ref="userService"/>
    </bean>

    <!--Service配置-->
    <bean name="userService" class="com.qwm.ssh_crm.service.UserServiceImpl"/>

    <!-- 指定spring读取db.properties配置 -->
    <context:property-placeholder location="classpath:db.properties"/>

    <!-- 将连接池放入spring容器 -->
    <bean name="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
        <property name="jdbcUrl" value="${jdbc.jdbcUrl}"/>
        <property name="driverClass" value="${jdbc.driverClass}"/>
        <property name="user" value="${jdbc.user}"/>
        <property name="password" value="${jdbc.password}"/>
    </bean>

    <bean name="sessionFactory" class="org.springframework.orm.hibernate5.LocalSessionFactoryBean">
        <!--装配连接池-->
        <property name="dataSource" ref="dataSource"/>
        <property name="hibernateProperties">
            <props>
                <prop key="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</prop>

                <!--  可选配置 -->
                <prop key="hibernate.show_sql">true</prop>
                <prop key="hibernate.format_sql">true</prop>
                <prop key="hibernate.hbm2ddl.auto">update</prop>
            </props>
        </property>
        <!-- 引入orm元数据,指定orm元数据所在的包路径,spring会自动读取包中的所有配置 -->
        <property name="mappingDirectoryLocations" value="classpath:com/qwm/ssh_crm/domain"></property>
    </bean>

    <!--dao配置-->
    <bean name="userDao" class="com.qwm.ssh_crm.dao.impl.UserDaoImpl">
        <property name="sessionFactory" ref="sessionFactory"/>
    </bean>
</beans>

四、测试与结果

4.1 测试代码

package com.qwm.test;

import com.qwm.ssh_crm.dao.UserDao;
import com.qwm.ssh_crm.domain.User;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;

import javax.annotation.Resource;

/**
 * @author:qiwenming
 * @date:2017/11/4 0004   17:38
 * @description:
 */
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration("classpath:applicationContext.xml")
public class DaoTest {

    @Resource(name = "userDao")
    private UserDao ud;

    /**
     * UserDao中 get测试
     */
    @Test
    public void test1(){
        User user = ud.getByUserCode("wm");
        System.out.println(user);
    }
}

4.2 结果

Hibernate:

    alter table cst_linkman
       add constraint FKh9yp1nql5227xxcopuxqx2e7q
       foreign key (lkm_cust_id)
       references cst_customer (cust_id)
Hibernate:
    select
        this_.user_id as user_id1_2_0_,
        this_.user_code as user_cod2_2_0_,
        this_.user_name as user_nam3_2_0_,
        this_.user_password as user_pas4_2_0_,
        this_.user_state as user_sta5_2_0_
    from
        sys_user this_
    where
        this_.user_code=?
User [user_id=1, user_code=wm, user_name=wiming, user_password=123456]

五、源码下载

https://github.com/wimingxxx/ssh_crm

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值