SpringBoot SSMP项目搭建保姆级教程

2023-10-22 11:15

本文主要是介绍SpringBoot SSMP项目搭建保姆级教程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、SpringBoot项目创建

  1. Idea中创建New Project,选择Spring Initializr,输入Name、Location、JDK等,下一步。
    在这里插入图片描述
  2. 选择合适的 SpringBoot 版本,点击创建。
    在这里插入图片描述
    此时,SpringBoot基础项目已经创建完毕。

二、Entity 开发

  1. 引入 lombok org.projectlombok。Lombok,一个Java类库,提供了一组注解,简化POJO实体类开发,SpringBoot目前默认集成了lombok技术,并提供了对应的版本控制,所以只需要提供对应的坐标即可,在pom.xml中添加lombok的坐标。

            <!--lombok--><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId></dependency>
    
  2. 创建 entity 目录,在其包下创建对应Entity。 由于已经引入 lombok,实体类上可直接使用 @Data 注解。使用lombok可以通过一个注解@Data 完成一个实体类对应的getter,setter,toString,equals,hashCode等操作的快速添加。

    package com.ty.entity;import lombok.Data;@Data
    public class User {private Integer id;private String name;private Integer age;}

三、DAO 开发

1、参数配置与Dao创建

  1. 导入MyBatisPlus 对应的starter mybatis-plus-boot-starter 与 mysql 驱动 mysql-connector-java

            <dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId><version>3.4.3</version></dependency><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>8.0.27</version><scope>runtime</scope></dependency>
    
  2. 创建对应mapper包,并创建 DemoMapper接口,由于使用MyBatisPlus技术,使用MP的标准通用接口BaseMapper加速开发,并添加注解 @Mapper 和泛型的指定。

    package com.ty.mapper;import com.baomidou.mybatisplus.core.mapper.BaseMapper;
    import com.ty.entity.User;
    import org.apache.ibatis.annotations.Mapper;@Mapper
    public interface DemoMapper extends BaseMapper<User> {
    }
    

    接口BaseMapper中默认提供了各种增删改查常用方法,继承后即可直接使用。
    在这里插入图片描述

  3. application.yml 配置文件中,配置数据库连接相关的数据源配置

    id-type: auto : 设置主键id字段的生成策略为参照数据库设定的策略,当前数据库设置id生成策略为自增。

    table-prefix: XX:设置表名通用前缀。

    spring:datasource:driver-class-name: com.mysql.cj.jdbc.Driverurl: jdbc:mysql://localhost:3306/tyusername: rootpassword: 123mybatis-plus:global-config:db-config:table-prefix: tbl_    #设置表名通用前缀id-type: auto     #设置主键id字段的生成策略为参照数据库设定的策略,当前数据库设置id生成策略为自增configuration:log-impl: org.apache.ibatis.logging.stdout.StdOutImpl   #输出MP运行日志
    

    mybatisplus提供了通过配置的形式就可以查阅执行期SQL语句,配置 log-impl: org.apache.ibatis.logging.stdout.StdOutImpl 会将生成 SQL与执行结果输出到控制台,也可选择其提供的各种输出方式。
    在这里插入图片描述

  4. 创建对应dao包,注入之前创建的demoMapper,即可直接使用MyBatisPlus自带的增删改查。

package com.ty.dao;import com.ty.entity.User;
import com.ty.mapper.DemoMapper;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;import java.util.List;@Component
public class DemoDao {@Autowiredprivate DemoMapper demoMapper;public void deleteUserById(Integer id){demoMapper.deleteById(id);}public void updateUser(User user){demoMapper.updateById(user);}
}

2、分页查询

Mybatis Plus提供了 selectPage 等分页查询方法。其中selectPage方法需传入一个由MybatisPlus封装分页数据的对象,可以通过new的形式创建这个对象 IPage page = new Page(pageNo, pageSize)

在这里插入图片描述
创建 dao包,随后创建 DemoDao 。

package com.ty.dao;import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.ty.entity.User;
import com.ty.mapper.DemoMapper;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;@Component
public class DemoDao {@Autowiredprivate DemoMapper demoMapper;public IPage selectUserByPage(Integer currentPage, Integer pageSize) {IPage page = new Page(currentPage,pageSize);return demoMapper.selectPage(page, null);}public void deleteUserById(Integer id){demoMapper.deleteById(id);}public void updateUser(User user){demoMapper.updateById(user);}
}

但对于MySQL,分页使用 limit,但其他数据库却不使用 limit。为提升 mybatis plus的兼容性,故将分页操作进行了拦截器形式优化。

定义mybatis plus 拦截器:
创建 Interceptor 包,并创建 MybatisPlusInterceptor 拦截器栈。

package com.ty.interceptor;import com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor;
import com.baomidou.mybatisplus.extension.plugins.inner.PaginationInnerInterceptor;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;@Configuration
public class MybatisPlusInterceptorConfig {@Beanpublic MybatisPlusInterceptor mybatisPlusInterceptor(){MybatisPlusInterceptor mybatisPlusInterceptor = new MybatisPlusInterceptor();mybatisPlusInterceptor.addInnerInterceptor(new PaginationInnerInterceptor());return mybatisPlusInterceptor;}}

通过测试类进行验证,此时分页查询已经生效。

在这里插入图片描述

总结

  • 使用IPage封装分页数据
  • 分页操作依赖MyBatisPlus分页拦截器实现功能
  • 借助MyBatisPlus日志查阅执行SQL语句

3、条件查询

以往我们写条件查询要自己动态拼写复杂的SQL语句,而 mybatis plus 提供有强大的条件查询功能。

  • 通过一个用于封装查询条件的对象QueryWrapper ,该对象可以动态使用API调用的方法添加条件,最终转化成对应的SQL语句。
  • 针对字段检查,mybatis plus 全面支持Lambda表达式,可代替QueryWrapper ,使用LambdaQueryWrapper对象。
  • 为了便于开发者动态拼写SQL,防止将null数据作为条件使用,userLambdaQueryWrapper.like(boolean condition, R column, Object val) 第一个参数Condition 可作为判空验证。
package com.ty.dao;import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.ty.entity.User;
import com.ty.mapper.DemoMapper;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;import java.util.List;@Component
public class DemoDao {@Autowiredprivate DemoMapper demoMapper;public IPage selectUserByPage(Integer currentPage, Integer pageSize) {IPage page = new Page(currentPage,pageSize);return demoMapper.selectPage(page, null);}public List<User> selectUserByName(String name) {LambdaQueryWrapper<User> userLambdaQueryWrapper = new LambdaQueryWrapper<>();userLambdaQueryWrapper.like(User::getName, name);userLambdaQueryWrapper.like(name != null, User::getName, name);return demoMapper.selectList(userLambdaQueryWrapper);}public void deleteUserById(Integer id){demoMapper.deleteById(id);}public void updateUser(User user){demoMapper.updateById(user);}public void insertUser(User user){demoMapper.insert(user);}
}

通过测试类进行验证,即可直接进行条件查询。

package com.ty;import com.baomidou.mybatisplus.core.metadata.IPage;
import com.ty.dao.DemoDaoImpl;
import com.ty.entity.User;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;import java.util.List;@SpringBootTest
class SpringbootSsmpDemoApplicationTests {@Autowiredprivate DemoDaoImpl demoDao;@Testvoid selectUserByNameTest() {List<User> ty = demoDao.selectUserByName("ty");System.out.println(ty);}
}

在这里插入图片描述

四、Service 开发

创建service包,创建 UserService接口与其对应的UserServiceImpl实现类。其中编写业务逻辑,没啥过多可说的。
注意使用 @Service 注解,将其加入 SpringBoot bean容器中。

在这里插入图片描述

package com.ty.service.impl;import com.baomidou.mybatisplus.core.metadata.IPage;
import com.ty.dao.DemoDao;
import com.ty.entity.User;
import com.ty.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;import java.util.List;@Service
public class UserServiceImpl implements UserService {@Autowiredprivate DemoDao demoDao;public List<User> queryUserByName(String name){return demoDao.selectUserByName(name);}public IPage queryUserByPage(Integer pageNo, Integer pageSize){return demoDao.selectUserByPage(pageNo, pageSize);}public void deleteUserById(Integer id){demoDao.deleteUserById(id);}public void updateUser(User user){demoDao.updateUser(user);}public void insertUser(User user){demoDao.insertUser(user);}
}

五、Controller 开发

继续创建 controller 包,创建基本的Controller实现类。

注意引入 @RestController@RequestMapping("/user") 注解,将该Controller注入 Springboot bean容器中,并设置通用访问 url 为 /user

package com.ty.controller;import com.ty.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;@RestController
@RequestMapping("/user")
public class UserController {@Autowiredprivate UserService userService;}

Restful接口开发

修改使用 @PutMapping,Post请求使用 @PostMapping, 删除使用 @DeleteMapping,Get请求使用 @GetMapping

package com.ty.controller;import com.baomidou.mybatisplus.core.metadata.IPage;
import com.ty.entity.User;
import com.ty.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;import java.util.List;@RestController
@RequestMapping("/user")
public class UserController {@Autowiredprivate UserService userService;@GetMapping("{name}")public List<User> getUserById(@PathVariable String name){return userService.queryUserByName(name);}@DeleteMapping("{id}")public void deleteUserById(@PathVariable Integer id){userService.deleteUserById(id);}/*** GET请求传递路径变量,后台实用@PathVariable接收数据*** @param pageNo* @param pageSize* @return*/@GetMapping("{pageNo}/{pageSize}")public IPage<User> getUserByPage(@PathVariable Integer pageNo,@PathVariable Integer pageSize){return userService.queryUserByPage(pageNo, pageSize);}@PutMappingpublic void updateUser(@RequestBody User user){userService.updateUser(user);}/*** 实体数据:@RequestBody* @param user*/@PostMappingpublic void addUser(@RequestBody User user){userService.insertUser(user);}
}

这篇关于SpringBoot SSMP项目搭建保姆级教程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/261072

相关文章

JavaScript中的isTrusted属性及其应用场景详解

《JavaScript中的isTrusted属性及其应用场景详解》在现代Web开发中,JavaScript是构建交互式应用的核心语言,随着前端技术的不断发展,开发者需要处理越来越多的复杂场景,例如事件... 目录引言一、问题背景二、isTrusted 属性的来源与作用1. isTrusted 的定义2. 为

Java循环创建对象内存溢出的解决方法

《Java循环创建对象内存溢出的解决方法》在Java中,如果在循环中不当地创建大量对象而不及时释放内存,很容易导致内存溢出(OutOfMemoryError),所以本文给大家介绍了Java循环创建对象... 目录问题1. 解决方案2. 示例代码2.1 原始版本(可能导致内存溢出)2.2 修改后的版本问题在

Java CompletableFuture如何实现超时功能

《JavaCompletableFuture如何实现超时功能》:本文主要介绍实现超时功能的基本思路以及CompletableFuture(之后简称CF)是如何通过代码实现超时功能的,需要的... 目录基本思路CompletableFuture 的实现1. 基本实现流程2. 静态条件分析3. 内存泄露 bug

Java中Object类的常用方法小结

《Java中Object类的常用方法小结》JavaObject类是所有类的父类,位于java.lang包中,本文为大家整理了一些Object类的常用方法,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. public boolean equals(Object obj)2. public int ha

SpringBoot项目中Maven剔除无用Jar引用的最佳实践

《SpringBoot项目中Maven剔除无用Jar引用的最佳实践》在SpringBoot项目开发中,Maven是最常用的构建工具之一,通过Maven,我们可以轻松地管理项目所需的依赖,而,... 目录1、引言2、Maven 依赖管理的基础概念2.1 什么是 Maven 依赖2.2 Maven 的依赖传递机

SpringBoot实现动态插拔的AOP的完整案例

《SpringBoot实现动态插拔的AOP的完整案例》在现代软件开发中,面向切面编程(AOP)是一种非常重要的技术,能够有效实现日志记录、安全控制、性能监控等横切关注点的分离,在传统的AOP实现中,切... 目录引言一、AOP 概述1.1 什么是 AOP1.2 AOP 的典型应用场景1.3 为什么需要动态插

Vue项目中Element UI组件未注册的问题原因及解决方法

《Vue项目中ElementUI组件未注册的问题原因及解决方法》在Vue项目中使用ElementUI组件库时,开发者可能会遇到一些常见问题,例如组件未正确注册导致的警告或错误,本文将详细探讨这些问题... 目录引言一、问题背景1.1 错误信息分析1.2 问题原因二、解决方法2.1 全局引入 Element

Java实现Excel与HTML互转

《Java实现Excel与HTML互转》Excel是一种电子表格格式,而HTM则是一种用于创建网页的标记语言,虽然两者在用途上存在差异,但有时我们需要将数据从一种格式转换为另一种格式,下面我们就来看看... Excel是一种电子表格格式,广泛用于数据处理和分析,而HTM则是一种用于创建网页的标记语言。虽然两

java图像识别工具类(ImageRecognitionUtils)使用实例详解

《java图像识别工具类(ImageRecognitionUtils)使用实例详解》:本文主要介绍如何在Java中使用OpenCV进行图像识别,包括图像加载、预处理、分类、人脸检测和特征提取等步骤... 目录前言1. 图像识别的背景与作用2. 设计目标3. 项目依赖4. 设计与实现 ImageRecogni

Java中Springboot集成Kafka实现消息发送和接收功能

《Java中Springboot集成Kafka实现消息发送和接收功能》Kafka是一个高吞吐量的分布式发布-订阅消息系统,主要用于处理大规模数据流,它由生产者、消费者、主题、分区和代理等组件构成,Ka... 目录一、Kafka 简介二、Kafka 功能三、POM依赖四、配置文件五、生产者六、消费者一、Kaf