码迷,mamicode.com
首页 > 编程语言 > 详细

spring对mytatis的xml配置以及quartz

时间:2014-12-11 14:09:54      阅读:237      评论:0      收藏:0      [点我收藏+]

标签:spring   mybatis   配置   

前言:使用spring+mybatis+mysql的框架构建Java代码已经有段时间了,但是对于applicationContext.xml文件中的配置项并没有很明确的概念性知识,经过阅读《spring实战3》,结合项目中运用的知识,对本文件的配置做一些说明,同时,非常迫切的希望有这方面经验的朋友对datasource的配置项提出一些指导性的建议。

Java项目

applicationContext.xml配置项中包含了 引入jdbc配置文件、创建jdbc数据源、quartz等,见以下内容

<?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:aop="http://www.springframework.org/schema/aop"
	xmlns:tx="http://www.springframework.org/schema/tx"
	xmlns:jdbc="http://www.springframework.org/schema/jdbc"
	xmlns:context="http://www.springframework.org/schema/context"
	xmlns:task="http://www.springframework.org/schema/task"
	xsi:schemaLocation="
     http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd
     http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
     http://www.springframework.org/schema/jdbc http://www.springframework.org/schema/jdbc/spring-jdbc-3.0.xsd
     http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd
     http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.0.xsd
     http://www.springframework.org/schema/task  
     http://www.springframework.org/schema/task/spring-task-3.1.xsd ">

	<!-- 引入jdbc配置文件 -->
	<bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
        <property name="locations">
            <value>conf/jdbc.properties</value>
        </property>
    </bean>
	
	<!--创建jdbc数据源 -->
	<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
		<property name="driverClassName" value="${driver}"></property>
		<!-- 加上utf8的编码方式后,项目在向数据库存放数据时会转码为utf8,获取数据时同样会最后转为utf8,这样就会防止编码不一致的时候出现乱码 -->
		<property name="url" value="${url}?useUnicode=true&characterEncoding=utf8&"></property>
		<property name="username" value="${username}"></property>
		<property name="password" value="${password}"></property>
		
		<!-- 初始化连接数 -->
		<property name="initialSize" value="10"></property>
		<!-- 最大连接数量 -->
		<property name="maxActive" value="100"></property>
		<!-- 最大空闲数量 -->
		<property name="maxIdle" value="20"></property>
		<!-- 最小空闲数量 -->
		<property name="minIdle" value="5"></property>
		<!-- 超时等待时间 -->
		<property name="maxWait" value="60000"></property>
		
		<!-- 开启池的prepared statement 池功能 -->
		<property name="poolPreparedStatements" value="true"></property>
		<!-- statement池能够同时分配的打开的statements的最大数量 -->
		<property name="maxOpenPreparedStatements" value="5"></property>
		
		<!-- 以下两个元素要一起使用,作用是为每次使用sqlsession的connection时进行验证,防止连接失效出现错误 -->
		<property name="testOnBorrow" value="true" />
		<property name="validationQuery">
			<value>select 1 from DUAL</value>
		</property>
	</bean>

	<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
		<!--实体类-->
		<property name="typeAliasesPackage" value="com.database.entity" />
		<property name="dataSource" ref="dataSource" />
	</bean>
	
	<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <property name="dataSource" ref="dataSource" />
    </bean>
    
    <!--
    	1.该元素除了替代annotation-config元素告诉spring我们使用注解的方式自动装配外,还允许spring自动检测bean和定义bean
    	2.base-package标识了该元素所扫描的包
    	3.include-filter过滤出expression所匹配的类
    -->
    <context:component-scan base-package="com.honzh.socket">
    	<context:include-filter type="regex" expression=".biz.*"/>
    	<context:include-filter type="regex" expression=".service.*"/>
    </context:component-scan>
    
	<!--定义注解驱动的事务,该元素告诉spring检查上下文中所有的bean并查找transactional注解的bean,不管是类级别还是方法级别-->
    <tx:annotation-driven/>
    
	<!--mybatis-spring提供的类,将mapper接口生成代理注入到spring中-->
    <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
        <property name="basePackage" value="com.honbase.mapper" />
    </bean>
    
	<!-- 定义quartz专属的工作类 -->
	<bean id="systemService" class="com.hoess.service.SystemService"></bean>
	
	<!-- 导入quartz的定时任务 -->
	<import resource="quartzConfig.xml" />
</beans>
上面我把注意点都通过注释写了出来,但是对于jdbc连接这块的参数值,并没有很确定值,下面是定时quartzConfig.xml任务的配置,见以下内容
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
	xmlns:tx="http://www.springframework.org/schema/tx" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xmlns:context="http://www.springframework.org/schema/context"
	xmlns:aop="http://www.springframework.org/schema/aop" xmlns:p="http://www.springframework.org/schema/p"
	xsi:schemaLocation="http://www.springframework.org/schema/beans 
       http://www.springframework.org/schema/beans/spring-beans.xsd
       http://www.springframework.org/schema/tx 
       http://www.springframework.org/schema/tx/spring-tx.xsd
       http://www.springframework.org/schema/context 
       http://www.springframework.org/schema/context/spring-context.xsd
       http://www.springframework.org/schema/aop
       http://www.springframework.org/schema/aop/spring-aop.xsd">
    <!-- 定时任务Quartz配置 -->
 <!-- 开盘 -->
    <bean id="open" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
    	<property name="targetObject">
    	    <ref bean="systemService"/>
    	</property>
    	<property name="targetMethod"> 
    	    <value>open</value>
    	</property>
    	<property name="concurrent">
            <value>false</value>
        </property>
    </bean>
    
    <bean id="openTime" class="org.springframework.scheduling.quartz.CronTriggerBean">
        <property name="jobDetail">
           <ref bean="open"/>
        </property>
        <property name="cronExpression">
             <value>0 0 19 * * ?</value>
        </property>
    </bean>
 <bean id="startQuertz" lazy-init="false" autowire="no" class="org.springframework.scheduling.quartz.SchedulerFactoryBean">
        <property name="triggers">
            <list>
                <ref bean="openTime"/>
         </list>
        </property>
    </bean>
</beans>
以上内容我就不加注释了,比较容易理解,然后是对应Java类执行方法
	// 开盘
	public void open() {
		logger.info("--------------------开盘------------------------");
	}

Java web项目

只有一个点不相同,我只把他列出来
<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:context="http://www.springframework.org/schema/context" xmlns:tx="http://www.springframework.org/schema/tx"
	xsi:schemaLocation="  
    http://www.springframework.org/schema/beans   
    http://www.springframework.org/schema/beans/spring-beans-3.0.xsd  
    http://www.springframework.org/schema/tx   
    http://www.springframework.org/schema/tx/spring-tx-3.0.xsd   
    http://www.springframework.org/schema/context   
    http://www.springframework.org/schema/context/spring-context-3.0.xsd">

	<!-- 引入jdbc配置文件 -->
	<context:property-placeholder location="classpath:jdbc.properties" />
导入的jdbc文件方式不一样,这种是spring最基本的外部文件导入方式,通过在类路径的src根目录找出jdbc配置。

总结:这些配置不是经常需要变动,一个项目只需要配置一次就够了。






spring对mytatis的xml配置以及quartz

标签:spring   mybatis   配置   

原文地址:http://blog.csdn.net/qing_gee/article/details/41864501

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!