zoukankan      html  css  js  c++  java
  • MyBatis学习之SpringMvc和MyBatis整合

    1. 整合流程

    Dao层:

    1. SqlMapConfig.xml,空文件即可,需要文件头。

    2. applicationContext-dao.xml。

      a) 数据库连接池

      b) SqlSessionFactory对象,需要spring和mybatis整合包下的。

      c) 配置mapper文件扫描器。

    Service层:

      1. applicationContext-service.xml包扫描器,扫描@service注解的类。

      2. applicationContext-trans.xml配置事务。

    表现层:

      Springmvc.xml

      1. 包扫描器,扫描@Controller注解的类。

      2. 配置注解驱动。

      3. 视图解析器

    Web.xml

      配置前端控制器。

    2. 详细思路

    2.1 sqlMapConfig.xml

    在classpath下创建mybatis/sqlMapConfig.xml

    <?xmlversion="1.0"encoding="UTF-8"?>
    <!DOCTYPEconfiguration
    PUBLIC"-//mybatis.org//DTD Config 3.0//EN"
    "http://mybatis.org/dtd/mybatis-3-config.dtd">
    <configuration>
    </configuration>

    2.2 applicationContext-dao.xml

    配置数据源、配置SqlSessionFactory、mapper扫描器。

    <?xmlversion="1.0"encoding="UTF-8"?>
    <beansxmlns="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.0.xsd
        http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.0.xsd
        http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.0.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.0.xsd
        http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-4.0.xsd">
        <!-- 加载配置文件 -->
        <context:property-placeholderlocation="classpath:db.properties"/>
        <!-- 数据库连接池 -->
        <beanid="dataSource"class="org.apache.commons.dbcp.BasicDataSource"
            destroy-method="close">
            <propertyname="driverClassName"value="${jdbc.driver}"/>
            <propertyname="url"value="${jdbc.url}"/>
            <propertyname="username"value="${jdbc.username}"/>
            <propertyname="password"value="${jdbc.password}"/>
            <propertyname="maxActive"value="10"/>
            <propertyname="maxIdle"value="5"/>
        </bean>
        <!-- mapper配置 -->
        <!-- 让spring管理sqlsessionfactory 使用mybatis和spring整合包中的 -->
        <beanid="sqlSessionFactory"class="org.mybatis.spring.SqlSessionFactoryBean">
            <!-- 数据库连接池 -->
            <propertyname="dataSource"ref="dataSource"/>
            <!-- 加载mybatis的全局配置文件 -->
            <propertyname="configLocation"value="classpath:mybatis/SqlMapConfig.xml"/>
        </bean>
        <!-- 配置Mapper扫描器 -->
        <beanclass="org.mybatis.spring.mapper.MapperScannerConfigurer">
            <propertyname="basePackage"value="cn.itcast.springmvc.mapper"/>
        </bean>
    </beans>

    Db.properties

    jdbc.driver=com.mysql.jdbc.Driver
    jdbc.url=jdbc:mysql://localhost:3306/springmvc?characterEncoding=utf-8
    jdbc.username=root
    jdbc.password=root

    2.3 applicationContext-service.xml

    <?xmlversion="1.0"encoding="UTF-8"?>
    <beansxmlns="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.0.xsd
        http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.0.xsd
        http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.0.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.0.xsd
        http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-4.0.xsd">
        <context:component-scanbase-package="cn.itcast.springmvc.service"/>
    </beans>

     applicationContext-transaction.xml

    <?xmlversion="1.0"encoding="UTF-8"?>
    <beansxmlns="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.0.xsd
        http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.0.xsd
        http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.0.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.0.xsd
        http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-4.0.xsd">
        <!-- 事务管理器 -->
        <beanid="transactionManager"
            class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
            <!-- 数据源 -->
            <propertyname="dataSource"ref="dataSource"/>
        </bean>
        <!-- 通知 -->
        <tx:adviceid="txAdvice"transaction-manager="transactionManager">
            <tx:attributes>
                <!-- 传播行为 -->
                <tx:methodname="save*"propagation="REQUIRED"/>
                <tx:methodname="insert*"propagation="REQUIRED"/>
                <tx:methodname="delete*"propagation="REQUIRED"/>
                <tx:methodname="update*"propagation="REQUIRED"/>
                <tx:methodname="find*"propagation="SUPPORTS"read-only="true"/>
                <tx:methodname="get*"propagation="SUPPORTS"read-only="true"/>
            </tx:attributes>
        </tx:advice>
        <!-- 切面 -->
        <aop:config>
            <aop:advisoradvice-ref="txAdvice"
                pointcut="execution(* cn.itcast.springmvc.service.*.*(..))"/>
        </aop:config>
    </beans>

    2.4 springmvc.xml

    <?xmlversion="1.0"encoding="UTF-8"?>
    <beansxmlns="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:dubbo="http://code.alibabatech.com/schema/dubbo"xmlns:mvc="http://www.springframework.org/schema/mvc"
        xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.0.xsd
            http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd
            http://code.alibabatech.com/schema/dubbo http://code.alibabatech.com/schema/dubbo/dubbo.xsd
            http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.0.xsd">
    
        <!-- 扫描带Controller注解的类 -->
        <context:component-scanbase-package="cn.itcast.springmvc.controller"/>
        <!-- 加载注解驱动 -->
        <mvc:annotation-driven/>
        <!-- 视图解析器 -->
        <beanclass="org.springframework.web.servlet.view.InternalResourceViewResolver">
            <propertyname="viewClass"
                value="org.springframework.web.servlet.view.JstlView"/>
            <!-- jsp前缀 -->
            <propertyname="prefix"value="/WEB-INF/jsp/"/>
            <!-- jsp后缀 -->
            <propertyname="suffix"value=".jsp"/>
        </bean>
    </beans>

    2.5  web.xml

    <?xmlversion="1.0"encoding="UTF-8"?>
    <web-appxmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xmlns="http://java.sun.com/xml/ns/javaee"
        xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
        id="WebApp_ID"version="2.5">
        <display-name>springmvc-web</display-name>
        <welcome-file-list>
            <welcome-file>index.html</welcome-file>
            <welcome-file>index.htm</welcome-file>
            <welcome-file>index.jsp</welcome-file>
            <welcome-file>default.html</welcome-file>
            <welcome-file>default.htm</welcome-file>
            <welcome-file>default.jsp</welcome-file>
        </welcome-file-list>
        <!-- 加载spring容器 -->
        <context-param>
            <param-name>contextConfigLocation</param-name>
            <param-value>classpath:spring/applicationContext-*.xml</param-value>
        </context-param>
        <listener>
            <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
        </listener>
        
        <servlet>
            <servlet-name>springmvc</servlet-name>
            <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
            <init-param>
                <param-name>contextConfigLocation</param-name>
                <param-value>classpath:spring/springmvc.xml</param-value>
            </init-param>
        </servlet>
        <servlet-mapping>
            <servlet-name>springmvc</servlet-name>
            <url-pattern>*.action</url-pattern>
        </servlet-mapping>
    </web-app>
  • 相关阅读:
    简单理解同步与异步
    Python3.x 安装Scrapy框架
    Python命名规范
    python 02/100例
    raw_input与input的区别
    二叉排序树
    串和广义表
    数据结构整理 第一章
    时间复杂度
    Music
  • 原文地址:https://www.cnblogs.com/sunfie/p/8975227.html
Copyright © 2011-2022 走看看