项目环境:

  • spring-4.3.7 + mybatis-3.3.0 + maven-3.3.9 + oracle11g

1. 首先使用maven引入相关依赖:

  • pom.xml:

    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
         <modelVersion>4.0.0</modelVersion>
         <groupId>com.ssm</groupId>
         <artifactId>ssm</artifactId>
         <packaging>war</packaging>
         <version>0.0.1-SNAPSHOT</version>
    
         <properties>
              <project.build.sourceEncoding>utf-8</project.build.sourceEncoding>
         </properties>
    
         <!-- spring官方提供的依赖管理器,便于统一管理 -->
         <dependencyManagement>
               <dependencies>
                    <dependency>
                         <groupId>org.springframework</groupId>
                         <artifactId>spring-framework-bom</artifactId>
                         <version>4.3.7.RELEASE</version>
                         <type>pom</type>
                         <scope>import</scope>
                    </dependency>
               </dependencies>
         </dependencyManagement>
    
         <dependencies>
               <!-- 引入web工程所需的依赖 -->
               <dependency>
                    <groupId>javax.servlet</groupId>
                    <artifactId>javax.servlet-api</artifactId>
                    <version>3.1.0</version>
                    <scope>provided</scope>
               </dependency>
               <dependency>
                    <groupId>javax.servlet.jsp</groupId>
                    <artifactId>jsp-api</artifactId>
                    <version>2.2</version>
                    <scope>provided</scope>
               </dependency>
    
               <!-- 引入测试所需的依赖,使用spring4.3.x版本整合需要引入junit4.12及以上 -->
               <dependency>
                    <groupId>junit</groupId>
                    <artifactId>junit</artifactId>
                    <version>4.12</version>
                    <scope>test</scope>i
               </dependency>
               <dependency>
                    <groupId>org.springframework</groupId>
                    <artifactId>spring-test</artifactId>
               </dependency>
    
               <!-- 整合SpringMVC会自动引入其他所需的spring核心依赖 -->
               <dependency>
                    <groupId>org.springframework</groupId>
                    <artifactId>spring-webmvc</artifactId>
               </dependency>
    
               <!-- 添加mybatis依赖 -->
               <dependency>
                    <groupId>org.mybatis</groupId>
                    <artifactId>mybatis</artifactId>
                    <version>3.3.0</version>
               </dependency>
               <!-- 添加mybatis与sping整合依赖 -->
               <dependency>
                    <groupId>org.springframework</groupId>
                    <artifactId>spring-orm</artifactId>
               </dependency>
               <dependency>
                    <groupId>org.mybatis</groupId>
                    <artifactId>mybatis-spring</artifactId>
                    <version>1.2.3</version>
               </dependency>
    
               <!-- 数据库依赖,使用oracle需要手动将oracle安装到本地maven仓库(版权问题) -->
               <dependency>
                    <groupId>com.oracle</groupId>
                    <artifactId>ojdbc7</artifactId>
                    <version>12.1.0.2</version>
               </dependency>
               <!-- dbcp数据库连接池依赖 -->
               <dependency>
                    <groupId>commons-dbcp</groupId>
                    <artifactId>commons-dbcp</artifactId>
                    <version>1.4</version>
              </dependency>
    
              <!-- logback日志依赖 -->
              <dependency>
                   <groupId>ch.qos.logback</groupId>
                   <artifactId>logback-classic</artifactId>
                   <version>1.1.7</version>
              </dependency>
    
               <!-- 添加JSTL标签库 -->
               <dependency>
                    <groupId>javax.servlet</groupId>
                    <artifactId>jstl</artifactId>
                    <version>1.2</version>
               </dependency>
               <dependency>
                    <groupId>taglibs</groupId>
                    <artifactId>standard</artifactId>
                    <version>1.1.2</version>
               </dependency>
         </dependencies>
    </project> 

2. 搭建mybatis环境:

  • 使用mapper代理的方式:定义一个接口EmployeeDao :

    public interface EmployeeDao {
    
        Employee selectById(Integer id);
    
        List<Employee> selectAll();
    
        int save(Employee emp);
    
        int update(Employee emp);
    
        int delete(Integer id);
    
    }
  • 对应的mapper映射文件:

    <?xml version="1.0" encoding="UTF-8" ?>
    <!DOCTYPE mapper
         PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
         "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
    
    <!-- namespace一定要对应接口的全类名 -->
    <mapper namespace="com.ssm.dao.EmployeeDao">
         <select id="selectById" parameterType="int" resultType="employee">
               select empno, ename, job, mgr, hiredate, sal, comm, deptno from emp where empno = #{empno}
         </select>
    
         <!-- mybatis会自动将结果集映射为employee的List -->
         <select id="selectAll" resultType="employee">
               select empno, ename, job, mgr, hiredate, sal, comm, deptno from emp
         </select>
    
         <update id="save" parameterType="employee">
               insert into emp(empno, ename, job, mgr, hiredate, sal, comm)
               values(#{empno}, #{ename}, #{job}, #{mgr}, #{hireDate}, #{sal},  #{comm})
         </update>
    
         <update id="update" parameterType="employee">
               update emp set ename = #{ename}, job = #{job}, mgr = #{mgr}, hiredate = #{hireDate}, sal = #{sal}, comm = #{comm} where empno = #{empno}
         </update>
    
         <delete id="delete" parameterType="int">
               delete from emp where empno = #{empno}
         </delete>
    
    </mapper>

3. spring整合mybatis

  1. 日志logback.xml:

    <?xml version="1.0" encoding="UTF-8"?>
    <configuration>
         <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
               <layout class="ch.qos.logback.classic.PatternLayout">
                    <Pattern>%d{HH:mm:ss} [%thread] %-5level %logger{36} - %msg %n
                    </Pattern>
               </layout>
         </appender>
         <logger name="com.base22" level="TRACE" />
         <root level="debug">
               <appender-ref ref="STDOUT" />
         </root>
    </configuration>
  2. jdbc.properties:
    jdbc.driverClass=oracle.jdbc.OracleDriver
    jdbc.url=jdbc:oracle:thin:@localhost:1521:orcl
    jdbc.username=scott
    jdbc.password=scott
  3. spring-mybatis.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-4.3.xsd
               http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.3.xsd">
    
         <context:property-placeholder location="classpath:jdbc.properties" />
    
         <!-- 配置c3p0数据源 -->
         <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"
               destroy-method="close">
               <property name="driverClass" value="${jdbc.driverClass}"></property>
               <property name="jdbcUrl" value="${jdbc.url}"></property>
               <property name="user" value="${jdbc.username}"></property>
               <property name="password" value="${jdbc.password}"></property>
         </bean>
    
         <!-- 注入MyBatis的SqlSessionFactory对象 -->
         <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
               <property name="dataSource" ref="dataSource"></property>
               <!-- 配置MyBatis全局配置文件 -->
               <property name="configLocation" value="classpath:mybatis-config.xml"></property>
               <!-- 扫描mapper需要的映射文件,可以使用通配符 -->
               <property name="mapperLocations" value="classpath:mapper/*.xml"></property>
               <!-- 扫描entity包,使用别名 -->
               <property name="typeAliasesPackage" value="com.ssm.entity"></property>
         </bean>
    
         <!-- 配置需要扫描的Dao接口,动态实现,并注入到spring的IOC容器中 -->
         <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
               <!-- 不建议注入sqlSessionFactory -->
               <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"></property>
               <!-- 配置需要扫描的Dao接口的包 -->
               <property name="basePackage" value="com.ssm.dao"></property>
         </bean>
    
         <!-- 扫描service层-->
      <context:component-scan base-package="com.ssm.service"></context:component-scan>
      <!-- 配置事务管理器 -->
      <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
           <property name="dataSource" ref="dataSource"></property>
      </bean>
      <!-- 开启注解式事务驱动 -->
      <tx:annotation-driven transaction-manager="transactionManager"/>
    
    </beans>

    dao层测试:

    //使用SpringRunner需要junit4.12及以上支持
    @RunWith(SpringRunner.class)
    @ContextConfiguration("classpath:spring-dao.xml")
    public class EmployeeDaoTest {
    
      private Logger log = LoggerFactory.getLogger(this.getClass());
    
      @Autowired
      private EmployeeDao employeeDao;
    
        @Test
        public void testSelectById() {
            Employee emp = employeeDao.selectById(7369);
            log.info("emp: {}", emp);
        }
    
        @Test
        public void testSelectAll() {
            List<Employee> list = employeeDao.selectAll();
            for(Employee emp : list) {
                log.info("list_emp: {}", emp);
            }
        }
    
        @Test
        public void testSave() {
            Employee emp = new Employee(1000, "ssm", "Java", 1000, 500.0, 1000.0, new Date());
            int saveCount = employeeDao.save(emp);
            log.info("saveCount: {}", saveCount);
       }
    
        @Test
        public void testUpdate() {
            Employee emp = employeeDao.selectById(1000);
            emp.setHireDate(new Date());
            int updateCount = employeeDao.update(emp);
            log.info("updateCount: {}", updateCount);
        }
    
        @Test
        public void testDelete() {
            int deleteCount = employeeDao.delete(1000);
            log.info("deleteCount: {}", deleteCount);
        }
    
    }

4. spring整合springmvc

  1. 首先需要在web.xml中配置springmvc的核心Servlet控制器:

    <servlet>
         <servlet-name>springDispatcherServlet</servlet-name>
         <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
         <init-param>
               <param-name>contextConfigLocation</param-name>
               <param-value>classpath:spring-*.xml</param-value>
         </init-param>
         <load-on-startup>1</load-on-startup>
    </servlet>
    <servlet-mapping>
         <servlet-name>springDispatcherServlet</servlet-name>
         <!-- 不要写成"/*" -->
         <url-pattern>/</url-pattern>
    </servlet-mapping>
  1. 写自己的handler

    @Controller
    @RequestMapping("/emp")
    public class EmployeeHandler {
    
        @Autowired
        private EmployeeService employeeService;
    
        @RequestMapping(value="/list")
        public String list(HttpServletRequest request) {
            List<Employee> list = employeeService.selectAll();
            request.setAttribute("employees", list);
            return "list";
        }
    
        @RequestMapping(value="/selectById")
        public String selectById(Integer id, HttpServletRequest request) {
            Employee emp = employeeService.selectById(id);
            request.setAttribute("employee", emp);
            return "details";
        }
    
        @RequestMapping(value="/add")
        public String add(Employee emp) {
            return "add";
        }
    
        @RequestMapping(value="/save")
        public String save(Employee emp) {
            employeeService.save(emp);
            return "redirect:list";
        }
    
        @RequestMapping(value="/update")
        public String update(Employee emp) {
            employeeService.update(emp);
            return "redirect:list";
        }
    
        @RequestMapping(value="/delete")
        public String delete(Integer id) {
            employeeService.delete(id);
            return "redirect:list";
        }
    
    }
  2. 配置spring-web.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"
        xmlns:mvc="http://www.springframework.org/schema/mvc"
        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
            http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd">
    
         <context:component-scanbase-package="com.ssm.web"></context:component-scan>
    
        <!-- 开启SpringMVC注解模式
           简化配置:
              1. 自动注册DefaultAnnotationHandlerMapping,AnnotationMethodHandlerAdapter
              2. 提供一系列默认支持:数据绑定、日期格式转换,xml&json支持
        -->
        <mvc:annotation-driven/>
    
        <!-- 静态资源默认servlet配置
               1. 加入对静态资源的处理:js,css,gif
               2. 允许使用"/"做整体映射
        -->
        <mvc:default-servlet-handler/>
    
        <!-- 配置视图解析器 -->
        <bean id="" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
            <property name="prefix" value="/WEB-INF/jsp/"></property>
            <property name="suffix" value=".jsp"></property>
        </bean>
    
    </beans>

使用Maven整合SSM总结的更多相关文章

  1. 用Maven整合SSM框架

    前述 Maven 是专门用于构建和管理Java相关项目的工具,利用 Maven 的主要目的是统一维护 jar 包.关于 Maven 的安装在这篇里面就不说了. SSM(Spring+SpringMVC ...

  2. Spring+SpringMVC+MyBatis+easyUI整合基础篇(六)maven整合SSM

    写在前面的话   承接前文<Spring+SpringMVC+MyBatis+easyUI整合基础篇(五)讲一下maven>,本篇所讲述的是如何使用maven与原ssm项目整合,使得一个普 ...

  3. maven 整合 ssm 异常分析

    异常一:使用tomcat 7 启动没问题访问(JSP)页面就报错:org.apache.jasper.JasperException: Unable to compile class for JSP ...

  4. IDEA+Maven 整合SSM框架实现简单的增删改查(新手入门,傻瓜操作)

    原博客地址:https://blog.csdn.net/khxu666/article/details/79851070 选用SSM框架的原因在目前的企业级Java应用中,Spring框架是必须的.S ...

  5. Maven整合SSM测试

    前面也说到了关于SSM的整合,话不多说直接从创建项目开始CRUD之路(参考前面写过的Mybatis和Spring整合,SSM简单整合),这是整个项目的结构 以及最终的结果.(附上下载地址) 一.创建M ...

  6. Maven整合SSM框架——详细整合教程(Spring+SpringMVC+MyBatis)

    使用SSM(Spring.SpringMVC和Mybatis)已经有三个多月了,项目在技术上已经没有什么难点了,基于现有的技术就可以实现想要的功能,当然肯定有很多可以改进的地方.之前没有记录SSM整合 ...

  7. maven整合ssm框架

    1.创建maven web工程 创建完成后,项目结构如下 2.项目配置文件 在pom.xml中添加SSM框架相关jar包的依赖关系,pom.xml代码如下 <?xml version=" ...

  8. 用Maven整合SSM项目实例

     转自https://www.cnblogs.com/hujianblogs/p/8526737.html 本人在学习Maven之余,为了深入了解Maven的用法,决定创建一个SSM整合实例.项目是自 ...

  9. 记录maven 整合SSM框架

    一.新建maven项目 建好的项目结构如下图: 还需要做以下配置: 勾选上这两项后,就会自动生成 "src/main/java"   和 "src/main/resour ...

随机推荐

  1. mysql 局域网同事之间直接用客户端访问

    情景: 几个人作为小组开发一个项目,以我的机器为服务器,将mysql服务安装在我的机器上,其他小伙伴用客户端都能访问我这个数据库 解决:   首先: 1.设置mysql允许其它机器连接(linux环境 ...

  2. 解决CenOS 7下启动ActiveMQ时报错

    基于 CentOS 7,ActiveMQ 5.9.1 问题重现 在 CentOS 7 下安装好ActiveMQ后,执行 /usr/local/apache-activemq-5.9.1/bin/act ...

  3. 关于Dapper.NET的相关论述

    年少时,为何不为自己的梦想去拼搏一次呢?纵使头破血流,也不悔有那年少轻狂.感慨很多,最近事情也很多,博客也很少更新了,毕竟每个人都需要为自己的生活去努力. 最近在一个群里遇到一个人说的话,在这里不再赘 ...

  4. 每天一个Linux命令 7

    常用yum命令1)查询 yum list #查询所有可用软件包列表yum search 关键字 #搜索服务器上所有和关键字相关的包2)安装 yum -y install 包名选项: install 安 ...

  5. RabbitMQ-从基础到实战(2)— 防止消息丢失

    转载请注明出处 1.简介 RabbitMQ中,消息丢失可以简单的分为两种:客户端丢失和服务端丢失.针对这两种消息丢失,RabbitMQ都给出了相应的解决方案. 2.防止客户端丢失消息 如图,生产者P向 ...

  6. python 接口自动化测试(一)

    一.测试需求描述 对服务后台一系列SOAP接口功能测试 参数传入:根据接口描述构造不同的参数输入值(Json格式) 二.程序设计 通过Excel配置具体的测试用例数据 保存参数为Json格式,预写入预 ...

  7. HTTP协议&SOCKET协议

    一. HTTP协议是什么? 我们在浏览器的地址栏里输入的网站地址叫做 URL(UniformResourceLocator,统一资源定位符).就像每家每户都有一个门牌地址一样,每个网页也都有一个Int ...

  8. Bug跟踪的流程

    本文以翼发云协同项目管理系统为例子来讲解Bug跟踪的流程,它以工作流为中心的集成式Bug跟踪软件,它广泛地应用于研发行业的产品缺陷管理 与跟踪.事务跟踪.问题跟踪.任务跟踪.查询跟踪.需求管理.变更跟 ...

  9. .net平台的MongoDB使用

    前言 最近花了点时间玩了下MongoDB.Driver,进行封装了工具库,平常也会经常用到MongoDB,因此写一篇文章梳理知识同时把自己的成果分享给大家. 本篇会设计到Lambda表达式的解析,有兴 ...

  10. 从Properties得到数据到gson转换为json

    从上一篇得到properties里的数据 Map<String,String> map = new HashMap<String,String>(); Enumeration& ...