登录
首页 >  数据库 >  MySQL

SSM三大框架的整合

来源:SegmentFault

时间:2023-02-24 14:40:42 388浏览 收藏

哈喽!今天心血来潮给大家带来了《SSM三大框架的整合》,想必大家应该对数据库都不陌生吧,那么阅读本文就都不会很困难,以下内容主要涉及到MySQL、Java、spring、mybatis、spring-mvc,若是你正在学习数据库,千万别错过这篇文章~希望能帮助到你!

好好学习,天天向上

文本已收录至我的Github仓库DayDayUP:github.com/RobodLee/DayDayUP,欢迎Star,更多文章请前往:目录导航

在Java后端开发领域,Spring+SpringMVC+MyBatis三大框架的使用尤为频繁,很多朋友学了这三个框架却不知道怎么整合起来,本文将带着大家一步步的实现三大框架的整合。我也是初学者,写作本文的目的一方面是想让大家少走点弯路,还有一方面是为了加深自己对于这三大框架的理解。整合的思路是以Spring框架为核心去整合SpringMVC和MyBatis框架。首先我们需要创建一个项目并且准备好测试用的数据库。

一.准备工作

怎么创建Maven工程我相信大家都会,我就不再赘述了,不会的朋友请自行百度。
我创建了一个叫SSMTest的项目,然后使用MySQL创建了一个叫ssmtest的数据库并且创建了一张user表,为了节省大家的时间,我将sql语句粘贴在这里:

create database ssmtest;
use ssmtest;
create table user(
id int primary key auto_increment,
name varchar(20),
age int
);

然后就需要准备好所需的jar包和配置文件,我将我的整个pom文件的内容都粘贴在这里,大家自行参考。

<?xml version="1.0" encoding="UTF-8"?><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/xsd/maven-4.0.0.xsd"><modelversion>4.0.0</modelversion><groupid>com.playman</groupid><a target='_blank'  href='https://www.17golang.com/gourl/?redirect=MDAwMDAwMDAwML57hpSHp6VpkrqbYLx2eayza4KafaOkbLS3zqSBrJvPsa5_0Ia6sWuR4Juaq6t9nq5roGCUgXuytMyerpZ5o9rFrWbekrrIrZK9ZWC8n3Zlx4GJpYlrcqyx3Z-klp-EnsV7ZpaOqbaOkpmghbNifqy4jY6HimqHscbRuKuOq4zftneG3oqmmWuarnalxWKoi7-BkZx9pIJqs5PahIWfr9S1oYPRh7qyqI2XenzEh4qDuYF5nH2kg4-z3bxqi4mrqLJkmb2Mtrmziql9mqurfZ6_gI1gf316aL-30WiOdoDdsmZ7zoXNz22Hupicr6yUnrKzhpx-kIZqvt3RdQ' rel='nofollow'>http://localhost</a>:8080/ssmtest/user/findAll路径就可以执行findAll()方法了,启动tomcat后在浏览器中输入该路径后按回车,看一下控制台的打印:</p><p></p><center><img referrerpolicy="no-referrer" src="/uploads/20230224/167722201763f860816f67d.png" alt="SpringMVC搭建结果" title="SpringMVC搭建结果" loading="lazy"></center><p>OK,方法正常执行了,说明我们的SpringMVC框架搭建成功了,现在就可以进行Spring和SpringMVC框架的整合了。</p><h2>四.Spring和SpringMVC框架的整合</h2><p>终于可以开始两个框架的整合了。话不多说,让我们开始吧!<br>如果我们可以在controller中成功调用到service中的方法就说明我们的框架整合没有问题,之前我们在单独使用Spring的时候是手动加载Spring容器,放在这里显然不太合适,所以我们需要在tomcat一启动的时候就自动加载Spring容器,怎么办呢?我们需要在web.xml中配置监听器实现启动时加载,添加以下内容:</p><p></p><pre class="brush:go;">  <!-- Spring整合SpringMVC-->
  <!-- 配置Spring的监听器,默认只加载WEB-INF目录下的applicationContext.xml配置文件,所以需要配置文件路径 -->
  <listener><listener-class>org.springframework.web.context.ContextLoaderListener</listener-class></listener><!-- 设置配置文件的路径 --><context-param><param-name>contextConfigLocation</param-name><param-value>classpath:applicationContext.xml</param-value></context-param>

现在修改UserController,在里面加入UserService,并调用UserService中的方法:

@Controller
@RequestMapping("/user")
public class UserController {

    @Autowired
    UserService userService;

    @RequestMapping("/findAll")
    public void findAll() {
        System.out.println("UserController中的findAll()方法执行了");
        userService.findAll();
    }

}

现在启动tomcat服务器,访问http://localhost:8080/ssmtest/user/findAll,看看执行结果。

Spring和SpringMVC框架的整合

很显然,我们的Spring框架和SpringMVC框架整合成功了,接下来我们就可以准备MyBatis框架了。

五.Spring框架整合MyBatis框架

本来我准备先搭建MyBatis框架,测一下有没有问题再进行整合,但是单独使用MyBatis框架需要准备配置文件,整合的时候又用不到,所以就跳过单独测试MyBatis框架,直接一边搭建一边整合。
使用过MyBatis框架的朋友们都应该知道我们在配置文件中配置了什么,无非就是配置dataSource和引入映射配置文件两件事情而已,然后在使用的时候就是创建SqlSession去初始化dao的实例。这些我们都可以将其配置到Spring的容器中去,这样就实现了Spring框架整合MyBatis框架。在applicationContext.xml文件中添加以下内容:

    <!-- Spring整合MyBatis框架 -->
    <!-- 配置连接池 -->
    <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"><property name="driverClass" value="com.mysql.jdbc.Driver"></property><property name="jdbcUrl" value="jdbc:mysql://127.0.0.1:3306/ssmtest"></property><property name="user" value="root"></property><property name="password" value="123456"></property></bean><!-- 配置SqlSessionFactory工厂 --><bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"><property name="dataSource" ref="dataSource"></property></bean><!-- 配置AccountDao接口所在包 --><bean id="mapperScannerConfigurer" class="org.mybatis.spring.mapper.MapperScannerConfigurer"><property name="basePackage" value="com.robod.dao"></property></bean>

这样我们就可以将其加载进Spring容器中了,接下来我们就在UserDao中加上相应的注解,并在UserServiceImpl中调用UseDao中的相应方法,然后在UserController中打印结果:
UserDao:

@Repository("userDao")
public interface UserDao {

    @Select("select * from user")
    public List<user> findAll();

    @Update("insert into user(name , age) values (#{name},#{age})")
    public void save(User user);

}
</user>

UserController:

    @RequestMapping("/findAll")
    public void findAll() {
        System.out.println("UserController中的findAll()方法执行了");
        List<user> users = userService.findAll();
        for (User user : users) {
            System.out.println(user.toString());
        }
    }</user>

这时候我们的数据库中还没有数据,我们先随便添加几条数据,然后再启动tomcat服务器,看一下结果:

Spring框架整合MyBatis框架

没有问题,至此我们的三大框架就整合完成啦!

六.Spring声明式事务管理

Spring中有个非常强大的功能就是声明式事务管理,我们当然不能忘了。配置Spring声明式事务管理有三个步骤,我在代码里加了注释,大家自己看,在applicationContext.xml中添加以下内容:

    <!-- 配置Spring框架声明式事务管理 -->
    <!-- (1)配置事务管理器 -->
    <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"><property name="dataSource" ref="dataSource"></property></bean><!-- (2)配置事务通知 --><a target='_blank'  href='https://www.17golang.com/gourl/?redirect=MDAwMDAwMDAwML57hpSHp6VpkrqbYLx2eayza4KafaOkbLS3zqSBrJvPsa5_0Ia6sWuR4Juaq6t9nq5roGCUgXuytMyerpZ5o9rFrWbekrrIrZK9ZWC8n3Zlx4GJpYlrcqyx3Z-klp-Ensiud9WcqpmKjs-FqbSchau5s3qZk46doLu3yoqXeZ-Yroh_qYK3sn6E0np_uImKgsaAsGCBpYd9r7ewe4d3Z5W4e6W5i7rIs4qtdpi2ZIquvpCSZJOki424p8qJl52E0bGfe7OKz9Rsgrp-daurfZ6usoabio2KbLKnuKSDhonQsZ52l5HQsbKHupdlsXmFrrNrhap9a45pvt3AooODdKI' rel='nofollow'>http://localhost</a>:8080/ssmtest/user/save</p><p></p><center><img referrerpolicy="no-referrer" src="/uploads/20230224/167722201863f86082787a9.png" alt="Spring声明式事务管理1" title="Spring声明式事务管理1" loading="lazy"></center><p>打开数据库可以看到,我们的save方法是没有问题的。现在为了能够看到我们的声明式事务管理是否可以正常运行,我们人为地加一点异常 ,修改UserServiceImpl的save方法:</p><p></p><pre class="brush:go;">    @Override
    public void save(List<user> users) {
        User user1 = users.get(0);
        User user2 = users.get(1);
        userDao.save(user1);
        int i = 1/0;    //如果事务没有回滚,那么应该可以正常添加一条数据
        userDao.save(user2);
    }</user>

为了看到对比的效果,我们先把声明式事务管理的配置删除掉,再删掉数据库中我们刚才添加的数据,运行一下:

Spring声明式事务管理2

Spring声明式事务管理3

可以看到,数据库中添加了一条数据,说明再没配置事务管理前出现异常是不会回滚的,现在我们将刚才删掉的配置代码再加上,删除数据库中的信息,再运行一下:

Spring声明式事务管理4

Spring声明式事务管理5

可以看到,数据库中一条数据都没有添加,说明真的回滚了,我们的声明式事务管理就配置成功了。到现在,所有的操作就全部完成啦!

微信公众号

今天关于《SSM三大框架的整合》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于mysql的内容请关注golang学习网公众号!

声明:本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>