mybatis(四)通过spring管理时的配置文件
1.首先是spring加载的配置文件,习惯命名为spring-dao.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:context="http://www.springframework.org/schema/context" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd"> <!-- 配置整合mybatis --> <!-- 1.配置数据库相关的参数 放在properties中属性 通过${url}形式取值--> <context:property-placeholder location="classpath:jdbc.properties"/> <!-- 2.配置数据库连接池--> <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"> <!-- 配置连接池属性 --> <property name="driverClass" value="${jdbc.driver}"/> <property name="jdbcUrl" value="${jdbc.url}"/> <property name="user" value="${jdbc.username}"/> <property name="password" value="${jdbc.password}"/> <!-- c3p0 连接池的私有属性 --> <property name="maxPoolSize" value="30"/> <property name="minPoolSize" value="10"/> <!-- 关闭后不自动commit --> <property name="autoCommitOnClose" value="false"/> <!-- 获取连接超时时间 --> <property name="checkoutTimeout" value="1000"/> <!-- 当获取连接失败时重试次数 --> <property name="acquireRetryAttempts" value="2"/> </bean> <!-- 3.设置sqlsessionfactory对象 --> <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <!-- 注入数据库连接池 --> <property name="dataSource" ref="dataSource"/> <!-- 配置MyBatis全局配置文件:mybatis-config.xml --> <property name="configLocation" value="classpath:mybatis-config.xml"/> <!-- 扫描sql配置文件:mapper需要的xml文件 --> <property name="mapperLocations" value="classpath:mapper/*.xml" /> <property name="typeAliasesPackage" value="cn.yyyyy.example.entity"/> </bean> <!-- 4:配置扫描Dao接口包,动态实现Dao接口,注入到Spring容器中 不设置ID因为无其他地方引用,自动运行 --> <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"> <!-- 注入SqlSessionFactory sqlSessionFactoryBeanName:防止处理时属性未被加载(jdbc.propertiemapperLocationss没被加载时,dataSource就是错误的) 通过BeanName后处理,使用Mybatis时再加载 --> <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"> </property> <!-- 给出需要扫描DAO接口包: 扫描特定的包,把包内的dao接口自动实现一个实现类,并注入Spring容器。 --> <property name="basePackage" value="cn.yyyyy.example.dao" /> </bean> </beans>
2.然后是mybatis核心配置文件,这个在sqlSessionFactory这个bean中会用到
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd"> <configuration> <!-- 配置全局属性 --> <settings> <!-- 使用jdbd的getGeneratedKeys 获取数据库自增主键值 --> <setting name="useGeneratedKeys" value="true"/> <!-- 使用列别名替换列名 --> <!--<setting name="useColumnLabel" value="true"/>--> <!-- 开启驼峰命名转换 --> <!--<setting name="mapUnderscoreToCamelCase" value="true"/>--> </settings> <!-- 数据库连接池事务等等的配置交给spring去处理配置 --> </configuration>
3.最后是数据库配置文件jdbc.properties
jdbc.driver=com.mysql.jdbc.Driver jdbc.url=jdbc:mysql://127.0.0.1:3306/seckill?useUnicode=true&characterEncoding=utf8 jdbc.username=root jdbc.password=root