Kwinz

学无止境,总在路上

Mybatis整合Spring的applicationContext配置

1.DTD information :添加Spring约束(可以添加更多实现更多功能)
<beans xmlns="http://www.springframework.org/schema/beans"
	xmlns:context="http://www.springframework.org/schema/context" 
	xmlns:p="http://www.springframework.org/schema/p"
	xmlns:aop="http://www.springframework.org/schema/aop" 
	xmlns:tx="http://www.springframework.org/schema/tx"
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	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
	http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.3.xsd 
	http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.3.xsd
	http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-4.3.xsd">


	
</beans>

2.加载配置文件

 <context:property-placeholder location="classpath:db.properties"/>
//db.properties是存储数据库连接池的配置。
db.properties例子:
jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/mybatis?characterEncoding=utf-8
jdbc.username=root
jdbc.password=123456

3.配置数据库连接池

Spring在第三方依赖包中包含了两个数据源的实现类包,其一是Apache的DBCP,其二是 C3P0。可以在Spring配置文件中利用这两者中任何一个配置数据源。举例使用DBCP*/
id:给bean取唯一的标志
class:导入类
destroy-method=”close”: 必须设定, 关闭数据源。当数据库连接不使用的时候,就把该连接重新放到数据池中,方便下次使用调用.
DBCP数据源还有一些常用的属性
   defaultAutoCommit:设置从数据源中返回的连接是否采用自动提交机制,默认值为 true; 
    defaultReadOnly:设置数据源是否仅能执行只读操作, 默认值为 false; 
    maxActive:最大连接数据库连接数,设置为0时,表示没有限制; 
    maxIdle:最大等待连接中的数量,设置为0时,表示没有限制; 
    maxWait:最大等待秒数,单位为毫秒, 超过时间会报出错误信息; 
    validationQuery:用于验证连接是否成功的查询SQL语句,SQL语句必须至少要返回一行数据, 如你可以简单地设置为:“select count(*) from user”; 
    removeAbandoned:是否自我中断,默认是 false ; 
    removeAbandonedTimeout:几秒后数据连接会自动断开,在removeAbandoned为true,提供该值; 
    logAbandoned:是否记录中断事件, 默认为 false; 
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"
            destroy-method="close">
            <property name="driverClassName" value="${jdbc.driver}" />
            <property name="url" value="${jdbc.url}" />
            <property name="username" value="${jdbc.username}" />
            <property name="password" value="${jdbc.password}" />
            <property name="maxActive" value="20" />
            <property name="maxActive" value="20" />
            <property name="maxIdle" value="8" />
</bean>

4.配置SqlSessionFactory

SqlSessionFactory是一个sql会话工厂,在这个工厂里面取得一个session会话丢给客户端使用


<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
    <!-- 配置mybatis核心配置文件 -->
    <!--注意:classpath:是相对于同一个包路劲下的。比如applicationContext.xml和SqlMapConfig.xml都在config包下
               name:取别名
    -->
    <property name="configLocation" value="classpath:SqlMapConfig.xml"/>
    <!-- 配置数据源 ref:引用-->
    <property name="dataSource" ref="dataSource"></property>
</bean>

5.将mapeer代理对象或者是dao实现类配置到spring容器中,让Spring负责管理对象

<!-- 下面三種取其中一种-->
      <!-- 开发dao,配置dao到spring中 -->
      <bean id="userDao" class="此处是dao实现类所在的qualified name">
            <!-- 配置sqlSessionFactory -->
            <property name="sqlSessionFactory" ref="sqlSessionFactory"></property>
      </bean>
      
      
      <!-- Mapper代理的方式开发方式一,配置Mapper代理对象 -->
      <bean id="userMapper" class="org.mybatis.spring.mapper.MapperFactoryBean">
            <!-- 配置Mapper接口 -->
            <property name="mapperInterface" value="此处是Mapper接口所在的qualified name"/>
            <!-- 配置sqlSessionFactory -->
            <property name="sqlSessionFactory" ref="sqlSessionFactory" />
      </bean>
      
      <!-- Mapper代理的方式开发方式二,扫描包方式配置代理 -->
      <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
            <!-- 配置Mapper接口 -->
            <property name="basePackage" value="此处是Mapper接口所在的qualified name"></property>
</bean>






阅读更多
版权声明:如笔记。一点一滴,伴我成长。可转载 https://blog.csdn.net/Butterfly_resting/article/details/79946809
个人分类: Mybatis Spring
上一篇执着
下一篇eclipse启动tomcat 访问http://localhost:8080 报404错误
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页

关闭
关闭