Spring整合mybatis的配置文件(非注解方式,无springMVC)

applicationContext.xml

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

	<!-- 加载properties配置文件 -->
	<bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
		<property name="locations">
			<list>
				<value>classpath:db.properties</value>
			</list>
		</property>
	</bean>
	
	<!-- 数据库信息存入dbcp -->
	<bean id="dbcp_bean" class="org.apache.commons.dbcp.BasicDataSource">
		<property name="driverClassName" value="${db_driver}"></property>
		<property name="url" value="${db_url}"></property>
		<property name="username" value="${db_username}"></property>
		<property name="password" value="${db_password}"></property>
	</bean>
	
	<!-- 加载mybatis的org.mybatis.spring.SqlSessionFactoryBean -->
	<!-- 如果使用加载资源文件的方式指定数据源,bean的id必须为sqlSessionFactory -->
	<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
		<!-- 注入dbcp -->
		<property name="dataSource" ref="dbcp_bean"></property>
		<!-- 为"com.gjy.model"包下的实体类起别名,根据需要修改value -->
		<property name="typeAliasesPackage" value="com.gjy.model"></property>
		<property name="plugins">
			<list>
				<!-- 添加分页插件 -->
				<ref bean="pageHelper_bean"/>
			</list>
		</property>
	</bean>
	
	<!-- 扫描"com.gjy.dao"包下的映射文件,根据需要修改value -->
	<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
		<property name="basePackage" value="com.gjy.dao"></property>
		<!-- 如果使用加载资源文件的方式指定数据源,SqlSessionFactoryBean的beanID强制为
		"sqlSessionFactory",那么下边这行不用且不能写;如果不使用加载资源文件的方式指定数据
		源,即不使用"$",那么SqlSessionFactoryBean的beanID不强制为"sqlSessionFactory",
		下边这行必须写,ref的值与SqlSessionFactoryBean的beanID保持一致 -->
		<!--
  		<property name="sqlSessionFactory" ref="sqlSessionFactory"></property> 
  		-->
	</bean>
	
	<!-- 配置mybatis的分页插件 -->
	<bean id="pageHelper_bean" class="com.github.pagehelper.PageHelper">
		<property name="properties">
			<props>
				<!-- 配置方言 -->
				<prop key="dialect">mysql</prop>
			</props>
		</property>
	</bean>
	
	<!-- 配置事务管理器 -->
	<bean id="transactionManager_bean" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
		<property name="dataSource" ref="dbcp_bean"></property>
	</bean>
	
	<!-- 事务的传播规则 -->
	<tx:advice id="tx_advice" transaction-manager="transactionManager_bean">
		<tx:attributes>
			<!-- 以下method name为方法名的前缀,根据需要修改;propagation为传播规则,
			一般默认REQUIRED;isolation为事务隔离级别;rollback-for表示在指定的异常
			出现后回滚 -->
			<tx:method name="add*" propagation="REQUIRED" isolation="DEFAULT" rollback-for="java.lang.NullPointerException" />
			<tx:method name="modify*" propagation="REQUIRED" isolation="READ_COMMITTED" no-rollback-for="java.lang.NullPointerException"/>
			<tx:method name="remove*" propagation="REQUIRED"/>
			<!-- 写下边这个其实就可以了,别整那些花里胡哨的 -->
			<tx:method name="*" propagation="REQUIRED"/>
		</tx:attributes>
	</tx:advice>
	
	<!-- aop实现事务管理 -->
	<aop:config>
		<!-- 切入点(方法的集合)
		expression的第一个"*"表示方法返回类型,"com.gjy.serviceImpl.*"表示
		"com.gjy.serviceImpl"包下的所有类,再".*"表示类中的所有方法,"()"里的
		".."表示方法的参数 -->
		<aop:pointcut id="aop_pointcut" expression="execution(* com.gjy.serviceImpl.*.*(..))"/>
		<!-- 通知 -->
		<aop:advisor pointcut-ref="aop_pointcut" advice-ref="tx_advice"/>
	</aop:config>
	
</beans>

附1:数据源文件(db.properties)

db_driver=com.mysql.jdbc.Driver
db_url=jdbc:mysql://localhost:3306/db_ssm?useUnicode=true&characterEncoding=UTF-8
db_username=root
db_password=root

附2:该配置文件的源码目录结构

在这里插入图片描述

附3:该配置文件所用到的jar包

在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值