spring4.x + hibernate4.x 配置详解

关于spring和hibernate的使用以及特征等等,在此不再啰嗦,相信大家也都知道,或者去搜索一下即可。

本篇博文的内容主要是我最近整理的关于spring4.x 和 hibernate 4.x 相关配置和使用方式,当然spring3.x以及hibernate4.x也可以借鉴。

首先是配置文件 web.xml 增加以下代码即可

<!-- 加载spring相关的配置文件 -->
<context-param>
    <param-name>contextConfigLocation</param-name>
    <param-value>classpath*:/applicationContext.xml</param-value>
</context-param>
<!-- 启用spring监听 -->
<listener>
    <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>

复制代码

然后建立 applicationContext.xml 文件 ,src下。 文件内容如下,注释我尽量写的很详细

<beans xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns="http://www.springframework.org/schema/beans" xmlns:aop="http://www.springframework.org/schema/aop"
    xmlns:context="http://www.springframework.org/schema/context" xmlns:tx="http://www.springframework.org/schema/tx"
    xmlns:cache="http://www.springframework.org/schema/cache" xmlns:p="http://www.springframework.org/schema/p"
    xsi:schemaLocation="http://www.springframework.org/schema/beans 
       http://www.springframework.org/schema/beans/spring-beans-4.0.xsd
       http://www.springframework.org/schema/aop
       http://www.springframework.org/schema/aop/spring-aop-4.0.xsd
       http://www.springframework.org/schema/context
       http://www.springframework.org/schema/context/spring-context-4.0.xsd
       http://www.springframework.org/schema/tx
       http://www.springframework.org/schema/tx/spring-tx-4.0.xsd
       http://www.springframework.org/schema/cache http://www.springframework.org/schema/cache/spring-cache-4.0.xsd">
    <!-- 引入properties文件 -->
    <context:property-placeholder location="classpath*:/appConfig.properties" />
    <!-- 定义数据库连接池数据源bean destroy-method="close"的作用是当数据库连接不使用的时候,就把该连接重新放到数据池中,方便下次使用调用 -->
    <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"
        destroy-method="close">
        <!-- 设置JDBC驱动名称 -->
        <property name="driverClass" value="${jdbc.driver}" />
        <!-- 设置JDBC连接URL -->
        <property name="jdbcUrl" value="${jdbc.url}" />
        <!-- 设置数据库用户名 -->
        <property name="user" value="${jdbc.username}" />
        <!-- 设置数据库密码 -->
        <property name="password" value="${jdbc.password}" />
        <!-- 设置连接池初始值 -->
        <property name="initialPoolSize" value="5" />
    </bean>

    <!-- 配置sessionFactory -->
    <bean id="sessionFactory"
        class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
        <!-- 数据源 -->
        <property name="dataSource" ref="dataSource" />

        <!-- hibernate的相关属性配置 -->
        <property name="hibernateProperties">
            <value>
                <!-- 设置数据库方言 -->
                hibernate.dialect=org.hibernate.dialect.MySQLDialect
                <!-- 设置自动创建|更新|验证数据库表结构 -->
                hibernate.hbm2ddl.auto=update
                <!-- 是否在控制台显示sql -->
                hibernate.show_sql=true
                <!-- 是否格式化sql,优化显示 -->
                hibernate.format_sql=true
                <!-- 是否开启二级缓存 -->
                hibernate.cache.use_second_level_cache=false
                <!-- 是否开启查询缓存 -->
                hibernate.cache.use_query_cache=false
                <!-- 数据库批量查询最大数 -->
                hibernate.jdbc.fetch_size=50
                <!-- 数据库批量更新、添加、删除操作最大数 -->
                hibernate.jdbc.batch_size=50
                <!-- 是否自动提交事务 -->
                hibernate.connection.autocommit=true
                <!-- 指定hibernate在何时释放JDBC连接 -->
                hibernate.connection.release_mode=auto
                <!-- 创建session方式 hibernate4.x 的方式 -->
                hibernate.current_session_context_class=org.springframework.orm.hibernate4.SpringSessionContext
                <!-- javax.persistence.validation.mode默认情况下是auto的,就是说如果不设置的话它是会自动去你的classpath下面找一个bean-validation**包 
                    所以把它设置为none即可 -->
                javax.persistence.validation.mode=none
            </value>
        </property>
        <!-- 自动扫描实体对象 tdxy.bean的包结构中存放实体类 -->
        <property name="packagesToScan" value="tdxy.bean" />
    </bean>
    <!-- 定义事务管理 -->
    <bean id="transactionManager"
        class="org.springframework.orm.hibernate4.HibernateTransactionManager">
        <property name="sessionFactory" ref="sessionFactory" />
    </bean>

    <!-- 定义 Autowired  自动注入 bean -->
    <bean class="org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor"/> 

    <!-- 扫描有注解的文件  base-package 包路径 -->
    <context:component-scan base-package="tdxy"/>

    <tx:advice id="txAdvice" transaction-manager="transactionManager">
        <tx:attributes>
            <!-- 事务执行方式
                REQUIRED:指定当前方法必需在事务环境中运行,
                如果当前有事务环境就加入当前正在执行的事务环境,
                如果当前没有事务,就新建一个事务。
                这是默认值。 
             -->
            <tx:method name="create*" propagation="REQUIRED" />
            <tx:method name="save*" propagation="REQUIRED" />
            <tx:method name="add*" propagation="REQUIRED" />
            <tx:method name="update*" propagation="REQUIRED" />
            <tx:method name="remove*" propagation="REQUIRED" />
            <tx:method name="del*" propagation="REQUIRED" />
            <tx:method name="import*" propagation="REQUIRED" />
            <!-- 
                指定当前方法以非事务方式执行操作,如果当前存在事务,就把当前事务挂起,等我以非事务的状态运行完,再继续原来的事务。 
                查询定义即可
                read-only="true"  表示只读
             -->
            <tx:method name="*" propagation="NOT_SUPPORTED" read-only="true" />
        </tx:attributes>
    </tx:advice>

    <!-- 定义切面,在 * tdxy.*.service.*ServiceImpl.*(..) 中执行有关的hibernate session的事务操作 -->
    <aop:config>
        <aop:pointcut id="serviceOperation" expression="execution(* tdxy.*.service.*Service.*(..))" />
        <aop:advisor advice-ref="txAdvice" pointcut-ref="serviceOperation" />
    </aop:config>

</beans>

applicationContext.xml 文件引用了一个properties文件 ,该文件也在src下,appConfig.properties 内容可以自己定义

jdbc.user=root
jdbc.password=000000
jdbc.driverClass=com.mysql.jdbc.Driver
jdbc.jdbcUrl=jdbc\:mysql\://localhost\:3306/mysql?useUnicode\=true&characterEncoding\=UTF-8
jdbc.initPoolSize=5
jdbc.maxPoolSize=10

自己写了一个test用的basedao

复制代码
package tdxy.dao;

import java.util.List;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Repository;

/**
*
* @Title: BaseDao.java
* @Package tdxy.dao
* @Description: TODO(baseDao 数据库操作实现类)
* @author dapeng
* @date 2014年5月7日 下午5:09:22
* @version V1.0
*/
@Repository
public class BaseDao {

/**
 * Autowired 自动装配 相当于get() set()
 */
@Autowired
protected SessionFactory sessionFactory;

/**
 * gerCurrentSession 会自动关闭session,使用的是当前的session事务
 * 
 * @return
 */
public Session getSession() {
    return sessionFactory.getCurrentSession();
}

/**
 * openSession 需要手动关闭session 意思是打开一个新的session
 * 
 * @return
 */
public Session getNewSession() {
    return sessionFactory.openSession();
}

public void flush() {
    getSession().flush();
}

public void clear() {
    getSession().clear();
}

/**
 * 根据 id 查询信息
 * 
 * @param id
 * @return
 */
@SuppressWarnings("rawtypes")
public Object load(Class c, String id) {
    Session session = getSession();
    return session.get(c, id);
}

/**
 * 获取所有信息
 * 
 * @param c 
 *        
 * @return
 */
@SuppressWarnings({ "rawtypes" })
public List getAllList(Class c) {
    String hql = "from " + c.getName();
    Session session = getSession();
    return session.createQuery(hql).list();
}

/**
 * 获取总数量
 * 
 * @param c
 * @return
 */
@SuppressWarnings("rawtypes")
public Long getTotalCount(Class c) {
    Session session = getNewSession();
    String hql = "select count(*) from " + c.getName();
    Long count = (Long) session.createQuery(hql).uniqueResult();
    session.close();
    return count != null ? count.longValue() : 0;
}

/**
 * 保存
 * 
 * @param bean 
 *            
 */
public void save(Object bean) {
    try {
        Session session = getNewSession();
        session.save(bean);
        session.flush();
        session.clear();
        session.close();
    } catch (Exception e) {
        e.printStackTrace();
    }
}

/**
 * 更新
 * 
 * @param bean 
 *            
 */
public void update(Object bean) {
    Session session = getNewSession();
    session.update(bean);
    session.flush();
    session.clear();
    session.close();
}

/**
 * 删除
 * 
 * @param bean 
 *            
 */
public void delete(Object bean) {
    Session session = getNewSession();
    session.delete(bean);
    session.flush();
    session.clear();
    session.close();
}

/**
 * 根据ID删除
 * 
 * @param c 类
 *            
 * @param id ID
 *            
 */
@SuppressWarnings({ "rawtypes" })
public void delete(Class c, String id) {
    Session session = getNewSession();
    Object obj = session.get(c, id);
    session.delete(obj);
    flush();
    clear();
}

/**
 * 批量删除
 * 
 * @param c 类
 *            
 * @param ids ID 集合
 *            
 */
@SuppressWarnings({ "rawtypes" })
public void delete(Class c, String[] ids) {
    for (String id : ids) {
        Object obj = getSession().get(c, id);
        if (obj != null) {
            getSession().delete(obj);
        }
    }
}

}
复制代码

不知大家有没有注意 applicationContext.xml 这样一句代码


hibernate.hbm2ddl.auto=update
这个意思是 只要在实体bean指定了entity,那么在数据库会自动创建对应的表和表结构

test用的一个实体bean

复制代码
package tdxy.bean;

import java.io.Serializable;

import javax.persistence.Entity;
import javax.persistence.Id;

/**
*
* @ClassName: UserInfoBean
* @Description: TODO(用户信息类)
* @author dapeng
* @date 2014年5月7日 上午12:13:44
* @version V1.0
*
*/
@Entity
public class UserInfoBean implements Serializable {

private static final long serialVersionUID = 7280747949998651159L;

@Id
private String id;
/**
 * 昵称
 */
private String nickName;
private String pwd;
/**
 * 等级
 * 
 */
private String level;

/**
 * 经验值
 */
private String emValue;
/**
 * 性别(0 男 1女)
 */
private String sex;
private String birthday;
private String qq;
private String email;
/**
 * 头像
 */
private String img;
/**
 * 所在地
 */
private String address;
/**
 * 签名
 */
private String qmd;

public String getId() {
    return id;
}

public void setId(String id) {
    this.id = id;
}

public String getNickName() {
    return nickName;
}

public void setNickName(String nickName) {
    this.nickName = nickName;
}

public String getPwd() {
    return pwd;
}

public void setPwd(String pwd) {
    this.pwd = pwd;
}

public String getLevel() {
    return level;
}

public void setLevel(String level) {
    this.level = level;
}

public String getEmValue() {
    return emValue;
}

public void setEmValue(String emValue) {
    this.emValue = emValue;
}

public String getSex() {
    return sex;
}

public void setSex(String sex) {
    this.sex = sex;
}

public String getBirthday() {
    return birthday;
}

public void setBirthday(String birthday) {
    this.birthday = birthday;
}

public String getQq() {
    return qq;
}

public void setQq(String qq) {
    this.qq = qq;
}

public String getEmail() {
    return email;
}

public void setEmail(String email) {
    this.email = email;
}

public String getImg() {
    return img;
}

public void setImg(String img) {
    this.img = img;
}

public String getAddress() {
    return address;
}

public void setAddress(String address) {
    this.address = address;
}

public String getQmd() {
    return qmd;
}

public void setQmd(String qmd) {
    this.qmd = qmd;
}

}
复制代码

当应用成功启动之后,数据库会出现表和结构,即刚才定义的bean是一样的,大家可以自己查看一下即可。

以下是test的Service

复制代码
package tdxy.user.service;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import tdxy.bean.UserInfoBean;
import tdxy.dao.BaseDao;
import tdxy.util.TdxyUtil;

@Service
public class UserInfoService {

@Autowired
private BaseDao baseDao;

public UserInfoBean queryUserInfoById(String id) {
    return (UserInfoBean) baseDao.load(UserInfoBean.class, id);
}

public void addUserInfo(UserInfoBean userInfo) {
    try {
        userInfo.setId(TdxyUtil.getId());
        userInfo.setAddress("32132");
        baseDao.save(userInfo);
    } catch (Exception e) {
        e.printStackTrace();
    }
}

}
复制代码

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值