• MyBatis+Spring整合


    MyBatis整合,PageHelper分页插件,Spring事物管理。

    MyBatis整合

    在web.xml配置放jdbc.properties等配置文件的目录路径。

    1
    2
    3
    4
    <context-param>
    <param-name>PROP_HOME</param-name>
    <param-value>/Users/**/config</param-value>
    </context-param>

    在spring的spring-mvc.xml引入上面配的PROP_HOME

    1
    2
    3
    4
    5
    6
    7
    <bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
    <property name="locations">
    <list>
    <value>file:///${PROP_HOME}/jdbc.properties</value>
    </list>
    </property>
    </bean>

    用c3p0配置连接池。

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
    <property name="jdbcUrl" value="${mysql.url}" />
    <property name="user" value="${mysql.username}" />
    <property name="password" value="${mysql.password}" />
    <property name="driverClass" value="${mysql.driverClassName}" />
    <property name="maxPoolSize" value="${mysql.maxPoolSize}"/>
    <property name="minPoolSize" value="${mysql.minPoolSize}"/>
    <property name="initialPoolSize" value="${mysql.initialPoolSize}"/>
    <property name="maxIdleTime" value="${mysql.maxIdleTime}"/>
    <property name="acquireIncrement" value="${mysql.acquireIncrement}"/>
    <property name="maxStatements" value="${mysql.maxStatements}"/>
    <property name="idleConnectionTestPeriod" value="${mysql.idleConnectionTestPeriod}"/>
    </bean>

    配置MyBatis。

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
    <property name="dataSource" ref="dataSource" />
    <property name="mapperLocations" value="classpath*:mappings/**/*apper.xml"/>
    <property name="typeAliasesPackage" value="com.bayes.entity"/>
    <property name="plugins">
    <array>
    <bean class=大专栏  MyBatis+Spring整合 class="string">"com.github.pagehelper.PageHelper">
    <property name="properties">
    <value>
    dialect=mysql
    offsetAsPageNum=true
    rowBoundsWithCount=true
    pageSizeZero=true
    reasonable=false
    supportMethodsArguments=false
    returnPageInfo=always
    params=pageNum=pageHelperStart;pageSize=pageHelperRows;
    </value>
    </property>
    </bean>
    </array>
    </property>
    </bean>

    配置MyBatis注解。

    1
    2
    3
    <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
    <property name="basePackage" value="com.bayes.mapper" />
    </bean>

    jdbc.properties配置内容。

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    mysql.driverClassName=com.mysql.jdbc.Driver
    mysql.url=jdbc:mysql://*.*.*.*:3306/***?useUnicode:true&characterEncoding:UTF-8&allowMultiQueries:true&noAccessToProcedureBodies=true
    mysql.username=***
    mysql.password=**#**
    mysql.initialPoolSize=20
    mysql.maxPoolSize=100
    mysql.minPoolSize=10
    mysql.maxIdleTime=600
    mysql.acquireIncrement=5
    mysql.maxStatements=5
    mysql.idleConnectionTestPeriod=60

    PageHelper分页插件集成Spring,以及使用

    PageHelper集成配置已经在上述配置MyBatis给出。
    官方github有详细文档,可参照。


    配置Spring事物管理

    配置Spring-jdbc事物。

    1
    2
    3
    <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
    <property name="dataSource" ref="dataSource"/>
    </bean>

    匹配符合规则的方法。

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    <tx:advice id="bayesAdvice" transaction-manager="transactionManager">
    <tx:attributes>
    <tx:method name="save*" propagation="REQUIRED"/>
    <tx:method name="del*" propagation="REQUIRED"/>
    <tx:method name="update*" propagation="REQUIRED"/>
    <tx:method name="add*" propagation="REQUIRED"/>
    <tx:method name="find*" propagation="REQUIRED"/>
    <tx:method name="get*" propagation="REQUIRED"/>
    <tx:method name="apply*" propagation="REQUIRED"/>
    </tx:attributes>
    </tx:advice>
    <aop:config>
    <aop:pointcut id="allAdviceServiceMethod" expression="execution(* com.bayes.service.*.*(..))"/>
    <aop:advisor pointcut-ref="allAdviceServiceMethod" advice-ref="bayesAdvice" />
    </aop:config>

  • 相关阅读:
    2019-12-18
    java读取XML文件,及封装XML字符串
    java不用中间变量交换两个值
    oracle获取当前月的第一个星期五
    2019-10-23
    HTTP中GET请求与POST请求的区别
    Java面试题整理(转载)
    java 字节流与字符流的区别
    20190822
    C++标准库string
  • 原文地址:https://www.cnblogs.com/lijianming180/p/12275699.html
Copyright © 2020-2023  润新知