项目环境:

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

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

  • pom.xml:

    1. <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    2. xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
    3. <modelVersion>4.0.0</modelVersion>
    4. <groupId>com.ssm</groupId>
    5. <artifactId>ssm</artifactId>
    6. <packaging>war</packaging>
    7. <version>0.0.1-SNAPSHOT</version>
    8.  
    9. <properties>
    10. <project.build.sourceEncoding>utf-8</project.build.sourceEncoding>
    11. </properties>
    12.  
    13. <!-- spring官方提供的依赖管理器,便于统一管理 -->
    14. <dependencyManagement>
    15. <dependencies>
    16. <dependency>
    17. <groupId>org.springframework</groupId>
    18. <artifactId>spring-framework-bom</artifactId>
    19. <version>4.3.7.RELEASE</version>
    20. <type>pom</type>
    21. <scope>import</scope>
    22. </dependency>
    23. </dependencies>
    24. </dependencyManagement>
    25.  
    26. <dependencies>
    27. <!-- 引入web工程所需的依赖 -->
    28. <dependency>
    29. <groupId>javax.servlet</groupId>
    30. <artifactId>javax.servlet-api</artifactId>
    31. <version>3.1.0</version>
    32. <scope>provided</scope>
    33. </dependency>
    34. <dependency>
    35. <groupId>javax.servlet.jsp</groupId>
    36. <artifactId>jsp-api</artifactId>
    37. <version>2.2</version>
    38. <scope>provided</scope>
    39. </dependency>
    40.  
    41. <!-- 引入测试所需的依赖,使用spring4.3.x版本整合需要引入junit4.12及以上 -->
    42. <dependency>
    43. <groupId>junit</groupId>
    44. <artifactId>junit</artifactId>
    45. <version>4.12</version>
    46. <scope>test</scope>i
    47. </dependency>
    48. <dependency>
    49. <groupId>org.springframework</groupId>
    50. <artifactId>spring-test</artifactId>
    51. </dependency>
    52.  
    53. <!-- 整合SpringMVC会自动引入其他所需的spring核心依赖 -->
    54. <dependency>
    55. <groupId>org.springframework</groupId>
    56. <artifactId>spring-webmvc</artifactId>
    57. </dependency>
    58.  
    59. <!-- 添加mybatis依赖 -->
    60. <dependency>
    61. <groupId>org.mybatis</groupId>
    62. <artifactId>mybatis</artifactId>
    63. <version>3.3.0</version>
    64. </dependency>
    65. <!-- 添加mybatis与sping整合依赖 -->
    66. <dependency>
    67. <groupId>org.springframework</groupId>
    68. <artifactId>spring-orm</artifactId>
    69. </dependency>
    70. <dependency>
    71. <groupId>org.mybatis</groupId>
    72. <artifactId>mybatis-spring</artifactId>
    73. <version>1.2.3</version>
    74. </dependency>
    75.  
    76. <!-- 数据库依赖,使用oracle需要手动将oracle安装到本地maven仓库(版权问题) -->
    77. <dependency>
    78. <groupId>com.oracle</groupId>
    79. <artifactId>ojdbc7</artifactId>
    80. <version>12.1.0.2</version>
    81. </dependency>
    82. <!-- dbcp数据库连接池依赖 -->
    83. <dependency>
    84. <groupId>commons-dbcp</groupId>
    85. <artifactId>commons-dbcp</artifactId>
    86. <version>1.4</version>
    87. </dependency>
    88.  
    89. <!-- logback日志依赖 -->
    90. <dependency>
    91. <groupId>ch.qos.logback</groupId>
    92. <artifactId>logback-classic</artifactId>
    93. <version>1.1.7</version>
    94. </dependency>
    95.  
    96. <!-- 添加JSTL标签库 -->
    97. <dependency>
    98. <groupId>javax.servlet</groupId>
    99. <artifactId>jstl</artifactId>
    100. <version>1.2</version>
    101. </dependency>
    102. <dependency>
    103. <groupId>taglibs</groupId>
    104. <artifactId>standard</artifactId>
    105. <version>1.1.2</version>
    106. </dependency>
    107. </dependencies>
    108. </project>

2. 搭建mybatis环境:

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

    1. public interface EmployeeDao {
    2.  
    3. Employee selectById(Integer id);
    4.  
    5. List<Employee> selectAll();
    6.  
    7. int save(Employee emp);
    8.  
    9. int update(Employee emp);
    10.  
    11. int delete(Integer id);
    12.  
    13. }
  • 对应的mapper映射文件:

    1. <?xml version="1.0" encoding="UTF-8" ?>
    2. <!DOCTYPE mapper
    3. PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
    4. "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
    5.  
    6. <!-- namespace一定要对应接口的全类名 -->
    7. <mapper namespace="com.ssm.dao.EmployeeDao">
    8. <select id="selectById" parameterType="int" resultType="employee">
    9. select empno, ename, job, mgr, hiredate, sal, comm, deptno from emp where empno = #{empno}
    10. </select>
    11.  
    12. <!-- mybatis会自动将结果集映射为employee的List -->
    13. <select id="selectAll" resultType="employee">
    14. select empno, ename, job, mgr, hiredate, sal, comm, deptno from emp
    15. </select>
    16.  
    17. <update id="save" parameterType="employee">
    18. insert into emp(empno, ename, job, mgr, hiredate, sal, comm)
    19. values(#{empno}, #{ename}, #{job}, #{mgr}, #{hireDate}, #{sal}, #{comm})
    20. </update>
    21.  
    22. <update id="update" parameterType="employee">
    23. update emp set ename = #{ename}, job = #{job}, mgr = #{mgr}, hiredate = #{hireDate}, sal = #{sal}, comm = #{comm} where empno = #{empno}
    24. </update>
    25.  
    26. <delete id="delete" parameterType="int">
    27. delete from emp where empno = #{empno}
    28. </delete>
    29.  
    30. </mapper>

3. spring整合mybatis

  1. 日志logback.xml:

    1. <?xml version="1.0" encoding="UTF-8"?>
    2. <configuration>
    3. <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
    4. <layout class="ch.qos.logback.classic.PatternLayout">
    5. <Pattern>%d{HH:mm:ss} [%thread] %-5level %logger{36} - %msg %n
    6. </Pattern>
    7. </layout>
    8. </appender>
    9. <logger name="com.base22" level="TRACE" />
    10. <root level="debug">
    11. <appender-ref ref="STDOUT" />
    12. </root>
    13. </configuration>
  2. jdbc.properties:
    1. jdbc.driverClass=oracle.jdbc.OracleDriver
    2. jdbc.url=jdbc:oracle:thin:@localhost:1521:orcl
    3. jdbc.username=scott
    4. jdbc.password=scott
  3. spring-mybatis.xml:
    1. <?xml version="1.0" encoding="UTF-8"?>
    2. <beans xmlns="http://www.springframework.org/schema/beans"
    3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    4. xmlns:context="http://www.springframework.org/schema/context"
    5. xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.3.xsd
    6. http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.3.xsd">
    7.  
    8. <context:property-placeholder location="classpath:jdbc.properties" />
    9.  
    10. <!-- 配置c3p0数据源 -->
    11. <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"
    12. destroy-method="close">
    13. <property name="driverClass" value="${jdbc.driverClass}"></property>
    14. <property name="jdbcUrl" value="${jdbc.url}"></property>
    15. <property name="user" value="${jdbc.username}"></property>
    16. <property name="password" value="${jdbc.password}"></property>
    17. </bean>
    18.  
    19. <!-- 注入MyBatis的SqlSessionFactory对象 -->
    20. <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
    21. <property name="dataSource" ref="dataSource"></property>
    22. <!-- 配置MyBatis全局配置文件 -->
    23. <property name="configLocation" value="classpath:mybatis-config.xml"></property>
    24. <!-- 扫描mapper需要的映射文件,可以使用通配符 -->
    25. <property name="mapperLocations" value="classpath:mapper/*.xml"></property>
    26. <!-- 扫描entity包,使用别名 -->
    27. <property name="typeAliasesPackage" value="com.ssm.entity"></property>
    28. </bean>
    29.  
    30. <!-- 配置需要扫描的Dao接口,动态实现,并注入到spring的IOC容器中 -->
    31. <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
    32. <!-- 不建议注入sqlSessionFactory -->
    33. <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"></property>
    34. <!-- 配置需要扫描的Dao接口的包 -->
    35. <property name="basePackage" value="com.ssm.dao"></property>
    36. </bean>
    37.  
    38. <!-- 扫描service层-->
    39.   <context:component-scan base-package="com.ssm.service"></context:component-scan>
    40.   <!-- 配置事务管理器 -->
    41.   <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
    42.   <property name="dataSource" ref="dataSource"></property>
    43.   </bean>
    44.   <!-- 开启注解式事务驱动 -->
    45.   <tx:annotation-driven transaction-manager="transactionManager"/>
    46.  
    47. </beans>

    dao层测试:

    1. //使用SpringRunner需要junit4.12及以上支持
    2. @RunWith(SpringRunner.class)
    3. @ContextConfiguration("classpath:spring-dao.xml")
    4. public class EmployeeDaoTest {
    5.  
    6.   private Logger log = LoggerFactory.getLogger(this.getClass());
    7.  
    8.   @Autowired
    9.   private EmployeeDao employeeDao;
    10.  
    11. @Test
    12. public void testSelectById() {
    13. Employee emp = employeeDao.selectById(7369);
    14. log.info("emp: {}", emp);
    15. }
    16.  
    17. @Test
    18. public void testSelectAll() {
    19. List<Employee> list = employeeDao.selectAll();
    20. for(Employee emp : list) {
    21. log.info("list_emp: {}", emp);
    22. }
    23. }
    24.  
    25. @Test
    26. public void testSave() {
    27. Employee emp = new Employee(1000, "ssm", "Java", 1000, 500.0, 1000.0, new Date());
    28. int saveCount = employeeDao.save(emp);
    29. log.info("saveCount: {}", saveCount);
    30.    }
    31.  
    32. @Test
    33. public void testUpdate() {
    34. Employee emp = employeeDao.selectById(1000);
    35. emp.setHireDate(new Date());
    36. int updateCount = employeeDao.update(emp);
    37. log.info("updateCount: {}", updateCount);
    38. }
    39.  
    40. @Test
    41. public void testDelete() {
    42. int deleteCount = employeeDao.delete(1000);
    43. log.info("deleteCount: {}", deleteCount);
    44. }
    45.  
    46. }

4. spring整合springmvc

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

    1. <servlet>
    2. <servlet-name>springDispatcherServlet</servlet-name>
    3. <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
    4. <init-param>
    5. <param-name>contextConfigLocation</param-name>
    6. <param-value>classpath:spring-*.xml</param-value>
    7. </init-param>
    8. <load-on-startup>1</load-on-startup>
    9. </servlet>
    10. <servlet-mapping>
    11. <servlet-name>springDispatcherServlet</servlet-name>
    12. <!-- 不要写成"/*" -->
    13. <url-pattern>/</url-pattern>
    14. </servlet-mapping>
  1. 写自己的handler

    1. @Controller
    2. @RequestMapping("/emp")
    3. public class EmployeeHandler {
    4.  
    5. @Autowired
    6. private EmployeeService employeeService;
    7.  
    8. @RequestMapping(value="/list")
    9. public String list(HttpServletRequest request) {
    10. List<Employee> list = employeeService.selectAll();
    11. request.setAttribute("employees", list);
    12. return "list";
    13. }
    14.  
    15. @RequestMapping(value="/selectById")
    16. public String selectById(Integer id, HttpServletRequest request) {
    17. Employee emp = employeeService.selectById(id);
    18. request.setAttribute("employee", emp);
    19. return "details";
    20. }
    21.  
    22. @RequestMapping(value="/add")
    23. public String add(Employee emp) {
    24. return "add";
    25. }
    26.  
    27. @RequestMapping(value="/save")
    28. public String save(Employee emp) {
    29. employeeService.save(emp);
    30. return "redirect:list";
    31. }
    32.  
    33. @RequestMapping(value="/update")
    34. public String update(Employee emp) {
    35. employeeService.update(emp);
    36. return "redirect:list";
    37. }
    38.  
    39. @RequestMapping(value="/delete")
    40. public String delete(Integer id) {
    41. employeeService.delete(id);
    42. return "redirect:list";
    43. }
    44.  
    45. }
  2. 配置spring-web.xml:
    1. <?xml version="1.0" encoding="UTF-8"?>
    2. <beans xmlns="http://www.springframework.org/schema/beans"
    3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    4. xmlns:context="http://www.springframework.org/schema/context"
    5. xmlns:mvc="http://www.springframework.org/schema/mvc"
    6. xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
    7. http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd
    8. http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd">
    9.  
    10. <context:component-scanbase-package="com.ssm.web"></context:component-scan>
    11.  
    12. <!-- 开启SpringMVC注解模式
    13.   简化配置:
    14. 1. 自动注册DefaultAnnotationHandlerMapping,AnnotationMethodHandlerAdapter
    15. 2. 提供一系列默认支持:数据绑定、日期格式转换,xml&json支持
    16. -->
    17. <mvc:annotation-driven/>
    18.  
    19. <!-- 静态资源默认servlet配置
    20. 1. 加入对静态资源的处理:js,css,gif
    21. 2. 允许使用"/"做整体映射
    22. -->
    23. <mvc:default-servlet-handler/>
    24.  
    25. <!-- 配置视图解析器 -->
    26. <bean id="" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
    27. <property name="prefix" value="/WEB-INF/jsp/"></property>
    28. <property name="suffix" value=".jsp"></property>
    29. </bean>
    30.  
    31. </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. UI设计需具备的几大素质

    近年来,IT产业对于高端技术人才需求加大,特别是北上广和知名企业对人才需求更为迫切,UI设计人员的正在接受UI培训的学员都赢认识到UI设计在未来要求将越来越高,交互设计越来越新颖也将对用户更加友好,兄 ...

  2. Unity3d场景漫游---iTween实现

    接触U3D以来,我做过的场景漫游实现方式一般有以下几种: Unity3d中的Animation组件,通过设置摄像机的关键点实现场景漫游 第一人称或第三人称控制器 编写摄像机控制脚本 iTween iT ...

  3. Spring框架(6)---AspectJ实现AOP

    AspectJ实现AOP 上一篇文章Spring框架(4)---AOP讲解铺垫,讲了一些基础AOP理解性的东西,那么这篇文章真正开始讲解AOP 通过AspectJ实现AOP要比普通的实现Aop要方便的 ...

  4. json基础入门

    json是什么? JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式,易于阅读和编写,同时也易于机器解析和生成.它基于ECMAScript的一个子集. JSO ...

  5. x86主机搭建家庭智能路由系统 ---- Proxmox虚拟化实现一机多用

    Proxmox VE简介 Proxmox VE(Proxmox Virtual Environment) 是一款完全开源虚拟化管理平台,可以管理QEMU/KVM虚拟机和LXC容器.事实上它只是一个前端 ...

  6. 基于Spring Cloud和Netflix OSS 构建微服务-Part 1

    前一篇文章<微服务操作模型>中,我们定义了微服务使用的操作模型.这篇文章中,我们将开始使用Spring Cloud和Netflix OSS实现这一模型,包含核心部分:服务发现(Servic ...

  7. 关于nodeJS多线程的支持,目前看来无法实现,讲解v8的一些东西

    关于这个,我这几天一直在研究,国内关于v8的资料很少,stackoverflow上也不多. 说起来我得说声抱歉,虽然并没有承诺什么.这个功能大概是无法实现.下面我来解释一下为什么. 首先我们要了解一下 ...

  8. wxWidgets 的 Linux / Windows 混合开发环境

    目标 建立一个开发 GUI 交互界面程序的环境,要求: 以 C/C++ 为主要程序设计语言. 最好能充分利用已有的 MFC 开发经验. 以 Linux 为主要开发环境.可以在 Windows 中编译并 ...

  9. ViewPager详解

    一.ViewPager简介 ViewPager 如其名所述,是负责翻页的一个 View.准确说是一个 ViewGrop,包含多个 View 页,在手指横向滑动屏幕时,其负责对 View 进行切换.为了 ...

  10. PHP语言开发微信公众平台(订阅号)之curl命令

    在开发过程中,经常会遇到要求用curl命令调用接口的情况 那么,什么是curl,简单来说curl是一个利用url语法规定来传输文件和哦数据的工具,支持很多协议,如 http.ftp.telent 等, ...