Data Access 之 MyBatis(六)- Spring、Spring MVC、MyBatis整合(下)

简介: Data Access 之 MyBatis(六)- Spring、Spring MVC、MyBatis整合(下)

db.properties配置了数据库连接的相关信息

jdbc_driver=com.mysql.cj.jdbc.Driver
jdbc_url=jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf8&autoReconnect=true&useSSL=false&serverTimezone=Asia/Shanghai
jdbc_username=root
jdbc_password=root
jdbc_initialSize=10
jdbc_maxActive=20
复制代码

2.4 MyBatis的配置

配置MyBatis全局配置文件mybatis-config.xml,只配置settings标签就可以,数据源、mapper等配置在Spring配置文件application.xml中设置。

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
    <settings>
        <!--开启驼峰命名-->
        <setting name="mapUnderscoreToCamelCase" value="true"/>
        <!--开启懒加载-->
        <setting name="lazyLoadingEnabled" value="true"/>
        <setting name="aggressiveLazyLoading" value="false"/>
        <!--开启二级缓存-->
        <setting name="cacheEnabled" value="true"/>
    </settings>
</configuration>
复制代码

在Spring配置文件application.xml中将Myabtis整合到Spring中,需要先导入Mybatis-Spring的依赖

<dependency>
    <groupId>org.mybatis</groupId>
    <artifactId>mybatis-spring</artifactId>
    <version>2.0.7</version>
</dependency>
复制代码

在application.xml中增加SqlSessionFactoryBean配置

<bean id="sqlSessionFactoryBean" class="org.mybatis.spring.SqlSessionFactoryBean">
    <property name="configLocation" value="mybatis-config.xml"></property>
    <property name="dataSource" ref="dataSource"></property>
    <property name="mapperLocations" value="classpath:/mappers/*.xml"></property>
</bean>
复制代码

将mapper包下的Mapper接口全部加入到Spring容器中

<!--持久层接口加入到Spring容器-->
<bean id="mapperScannerConfigurer" class="org.mybatis.spring.mapper.MapperScannerConfigurer">
    <!--指定接口所在的包-->
    <property name="basePackage" value="com.citi.mapper"></property>
</bean>
复制代码

2.5 其他配置

mybatis日志配置logback.xml,放在resource目录下。可以在控制台打印出SQL

<?xml version="1.0" encoding="UTF-8"?>
<configuration>
   <appender name="console" class="ch.qos.logback.core.ConsoleAppender">
       <encoder>
           <pattern>[%thread] %d{HH:mm:ss.SSS} %-5level %logger{36} - %msg%n</pattern>
       </encoder>
   </appender>
    <root level="debug">
        <appender-ref ref="console"/>
    </root>
</configuration>
复制代码

至此Spring、Spring MVC、MyBatis三个框架整合完成

3.测试

持久层Mapper接口测试

数据库表与上一篇QA 由浅入深持久层框架(七)- MyBatis Cache用到的是同一张表,即t_teacher,这里不再重复

新建entity包,增加Teacher实体类

@Data
public class Teacher implements Serializable {
    private Integer id;
    private String teacherName;
    private String className;
    private String address;
    private Date birthDate;
}
复制代码

新建mapper包,增加TeacherMapper接口,并增加一个根据id查询Teahcer的方法

public interface TeacherMapper {
    Teacher getTeacherById(Integer id);
}
复制代码

在resources目录下新增mappers文件夹,用来存放Mapper接口的SQL映射文件,新建TeacherMapper接口的SQL映射文件TeacherMapper.xml

<?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">
<mapper namespace="com.citi.mapper.TeacherMapper">
    <!--开启二级缓存-->
    <cache></cache>
    <select id="getTeacherById" resultType="com.citi.entity.Teacher">
        select * from t_teacher where id = #{id}
    </select>
</mapper>
复制代码

在test包下新增TeacherMapper接口的测试类TeacherMapperTest,新增getTeacherById方法的测试方法

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations = "classpath:application.xml")
public class TeacherMapperTest {
    @Autowired
    private TeacherMapper teacherMapper;
    @Test
    public void getTeacherById() {
        teacherMapper.getTeacherById(1);
    }
}
复制代码

测试类中用到了Spring Test,主要不要忘记类上的两个注解

执行测试方法

a802da69669d48ea9080040dbe723876_tplv-k3u1fbpfcp-zoom-in-crop-mark_4536_0_0_0.png

成功查询到了id为2的Teacher对象

Service层测试

新建service包,在该包下新增TeacherService接口,新增一个根据id查找Teacher的方法

public interface TeacherService {
    Teacher findTeacherById(Integer id);
}
复制代码

在service包下新增impl包,用来保存接口的实现类,在impl包中新增TeacherService接口的实现类TeacherServiceImpl

@Service
public class TeacherServiceImpl implements TeacherService {
    @Autowired
    private TeacherMapper teacherMapper;
    @Override
    public Teacher findTeacherById(Integer id) {
        return teacherMapper.getTeacherById(id);
    }
}
复制代码

增加TeacherService的测试类TeacherServiceTest

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations = "classpath:application.xml")
public class TeacherServiceTest {
    @Autowired
    private TeacherService teacherService;
    @Test
    public void findTeacherById() {
        Teacher teacher = teacherService.findTeacherById(1);
        System.out.println(teacher);
    }
}
复制代码

执行测试

image.png

控制台成功输出id为1的Teacher对象,说明service层调用mapper层成功

Controller层测试

配置Tomcat前,首先选中项目,点击IDEA菜单的File选项,点击Project Structure,左边选择Artifacts,在WEB-INF下新建一个lib目录,将右侧的jar包全部选中并导入lib文件夹中

image.png

配置Tomcat,点击IDEA的DEIT Configurations,配置一个本地的Tomcat

image.png

并将项目部署到Tomcat中

image.png

编写Controller层代码,新建controller包,增加TeacherController类

@Controller
@RequestMapping("/teacher")
public class TeacherController {
    @Resource
    public TeacherService teacherService;
    @RequestMapping("/{id}")
    public ModelAndView findTeacher(@PathVariable("id") Integer id){
        Teacher teacher = teacherService.findTeacherById(id);
        ModelAndView modelAndView = new ModelAndView();
        modelAndView.addObject("teacher",teacher);
        modelAndView.setViewName("success");
        return modelAndView;
    }
}
复制代码

视图解析器已经配置了WEB-INF下的pages目录,所以在WEB-INF下新增pages目录并新增一个jsp文件success.jsp

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>Title</title>
</head>
<body>
    <h2>SUCCESS</h2>
    <h3>${teacher}</h3>
</body>
</html>
复制代码

启动Tomcat,浏览器输入地址http://localhost:8080/teacher/1, 查询id为1的Teacher的信息

image.png

Spring、Spring MVC、MyBatis整合成功!


相关文章
|
13天前
|
SQL Java 数据库连接
对Spring、SpringMVC、MyBatis框架的介绍与解释
Spring 框架提供了全面的基础设施支持,Spring MVC 专注于 Web 层的开发,而 MyBatis 则是一个高效的持久层框架。这三个框架结合使用,可以显著提升 Java 企业级应用的开发效率和质量。通过理解它们的核心特性和使用方法,开发者可以更好地构建和维护复杂的应用程序。
100 29
|
12天前
|
存储 NoSQL Java
使用Java和Spring Data构建数据访问层
本文介绍了如何使用 Java 和 Spring Data 构建数据访问层的完整过程。通过创建实体类、存储库接口、服务类和控制器类,实现了对数据库的基本操作。这种方法不仅简化了数据访问层的开发,还提高了代码的可维护性和可读性。通过合理使用 Spring Data 提供的功能,可以大幅提升开发效率。
56 21
|
24天前
|
前端开发 Java 数据库连接
Java后端开发-使用springboot进行Mybatis连接数据库步骤
本文介绍了使用Java和IDEA进行数据库操作的详细步骤,涵盖从数据库准备到测试类编写及运行的全过程。主要内容包括: 1. **数据库准备**:创建数据库和表。 2. **查询数据库**:验证数据库是否可用。 3. **IDEA代码配置**:构建实体类并配置数据库连接。 4. **测试类编写**:编写并运行测试类以确保一切正常。
43 2
|
1月前
|
SQL JavaScript Java
Spring Boot 3 整合 Mybatis-Plus 实现数据权限控制
本文介绍了如何在Spring Boot 3中整合MyBatis-Plus实现数据权限控制,通过使用MyBatis-Plus提供的`DataPermissionInterceptor`插件,在不破坏原有代码结构的基础上实现了细粒度的数据访问控制。文中详细描述了自定义注解`DataScope`的使用方法、`DataPermissionHandler`的具体实现逻辑,以及根据用户的不同角色和部门动态添加SQL片段来限制查询结果。此外,还展示了基于Spring Boot 3和Vue 3构建的前后端分离快速开发框架的实际应用案例,包括项目的核心功能模块如用户管理、角色管理等,并提供Gitee上的开源仓库
210 11
|
2月前
|
设计模式 前端开发 Java
步步深入SpringMvc DispatcherServlet源码掌握springmvc全流程原理
通过对 `DispatcherServlet`源码的深入剖析,我们了解了SpringMVC请求处理的全流程。`DispatcherServlet`作为前端控制器,负责请求的接收和分发,处理器映射和适配负责将请求分派到具体的处理器方法,视图解析器负责生成和渲染视图。理解这些核心组件及其交互原理,有助于开发者更好地使用和扩展SpringMVC框架。
64 4
|
2月前
|
缓存 Java 数据库连接
深入探讨:Spring与MyBatis中的连接池与缓存机制
Spring 与 MyBatis 提供了强大的连接池和缓存机制,通过合理配置和使用这些机制,可以显著提升应用的性能和可扩展性。连接池通过复用数据库连接减少了连接创建和销毁的开销,而 MyBatis 的一级缓存和二级缓存则通过缓存查询结果减少了数据库访问次数。在实际应用中,结合具体的业务需求和系统架构,优化连接池和缓存的配置,是提升系统性能的重要手段。
137 4
|
2月前
|
SQL Java 数据库连接
spring和Mybatis的各种查询
Spring 和 MyBatis 的结合使得数据访问层的开发变得更加简洁和高效。通过以上各种查询操作的详细讲解,我们可以看到 MyBatis 在处理简单查询、条件查询、分页查询、联合查询和动态 SQL 查询方面的强大功能。熟练掌握这些操作,可以极大提升开发效率和代码质量。
154 3
|
3月前
|
前端开发 Java 开发者
Spring MVC中的请求映射:@RequestMapping注解深度解析
在Spring MVC框架中,`@RequestMapping`注解是实现请求映射的关键,它将HTTP请求映射到相应的处理器方法上。本文将深入探讨`@RequestMapping`注解的工作原理、使用方法以及最佳实践,为开发者提供一份详尽的技术干货。
221 2
|
3月前
|
Java 数据库连接 数据库
spring和Mybatis的逆向工程
通过本文的介绍,我们了解了如何使用Spring和MyBatis进行逆向工程,包括环境配置、MyBatis Generator配置、Spring和MyBatis整合以及业务逻辑的编写。逆向工程极大地提高了开发效率,减少了重复劳动,保证了代码的一致性和可维护性。希望这篇文章能帮助你在项目中高效地使用Spring和MyBatis。
86 1
|
4月前
|
前端开发 Java Apache
Springboot整合shiro,带你学会shiro,入门级别教程,由浅入深,完整代码案例,各位项目想加这个模块的人也可以看这个,又或者不会mybatis-plus的也可以看这个
本文详细讲解了如何整合Apache Shiro与Spring Boot项目,包括数据库准备、项目配置、实体类、Mapper、Service、Controller的创建和配置,以及Shiro的配置和使用。
892 1
Springboot整合shiro,带你学会shiro,入门级别教程,由浅入深,完整代码案例,各位项目想加这个模块的人也可以看这个,又或者不会mybatis-plus的也可以看这个