当前位置: 首页 > news >正文

基于SpringBoot的SSM整合案例

项目目录:

数据库表以及表结构

user表结构

user_info表结构

引入依赖

父模块依赖:
<parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.2.12.RELEASE</version></parent>
<properties>中的版本管理
<!--mybatis版本--><mybatis.spring.version>2.2.2</mybatis.spring.version><!--Druid版本--><druid.version>1.2.11</druid.version><!--mysql版本--><mysql.version>5.1.38</mysql.version>
<dependences>依赖:
<!--应用程序的web起步依赖,包含了构建web应用程序所需的基本组件和依赖--><!--使用该依赖可以快速启动一个基于SpringMVC的应用程序--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><!--添加测试依赖,该依赖用于在SpringBoot应用程序中进行单元测试和继承测试--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-jdbc</artifactId></dependency><dependency><groupId>org.mybatis.spring.boot</groupId><artifactId>mybatis-spring-boot-starter</artifactId><version>${mybatis.spring.version}</version></dependency><dependency><groupId>com.alibaba</groupId><artifactId>druid-spring-boot-starter</artifactId><version>${druid.version}</version></dependency><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>${mysql.version}</version></dependency><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId></dependency>

添加配置文件

application.xml
spring:profiles:active: dev
server:port: 8088servlet:context-path: /ssm
mybatis:config-location: classpath:mybatis/mybatis-config.xmlmapper-locations: classpath:mybatis/**/*Mapper.xml
application-dev.xml
# 数据源配置
spring:datasource:type: com.alibaba.druid.pool.DruidDataSourcedriverClassName: com.mysql.jdbc.Driverurl: jdbc:mysql://localhost:3306/ssm?useUnicode=true&characterEncoding=utf-8&useSSL=falseusername: rootpassword: rootdruid:# 初始连接数initialSize: 5# 最小连接池数量minIdle: 10# 最大连接池数量maxActive: 20# 配置获取连接等待超时的时间maxWait: 60000# 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒timeBetweenEvictionRunsMillis: 60000# 配置一个连接在池中最小生存的时间,单位是毫秒minEvictableIdleTimeMillis: 300000# 配置一个连接在池中最大生存的时间,单位是毫秒maxEvictableIdleTimeMillis: 900000# 配置检测连接是否有效validationQuery: SELECT 1 FROM DUALtestWhileIdle: truetestOnBorrow: falsetestOnReturn: falsewebStatFilter:enabled: truestatViewServlet:enabled: true# 设置白名单,不填则允许所有访问allow:# 指定访问druid监控页面的请求映射路径# 开发中一般通过:服务器映射路径/druid/index,来访问监控页面url-pattern: /druid/*# 监控默认是可以直接访问的# 如果有以下配置,那么访问监控页面时会跳转到,控制台管理页面进行登录控制# 控制台管理用户名和密码login-username: druidlogin-password: druidfilter:stat:enabled: true# 慢SQL记录(控制慢查询sql语句显示为红色提醒)log-slow-sql: trueslow-sql-millis: 1000merge-sql: truewall:config:multi-statement-allow: true
全局配置文件mybatis-config.xml
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configurationPUBLIC "-//mybatis.org//DTD Config 3.0//EN""https://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration><settings><setting name="logImpl" value="STDOUT_LOGGING"/></settings>
</configuration>
MybatisConfig配置类(用于扫描mapper接口包)
@Configuration
@MapperScan("com.yaorange.mapper")
public class MyBatisConfig {
}

公共类包

返回结果以及常量
public interface CommonConstant {/*** {@code 500 Server Error} (HTTP/1.0 - RFC 1945)*/Integer SC_INTERNAL_SERVER_ERROR_500 = 500;/*** {@code 200 OK} (HTTP/1.0 - RFC 1945)*/Integer SC_OK_200 = 2000;String ERROR_MSG = "操作失败";String OK_MSG = "操作成功";String LOGIN_ERROR_MSG = "用户名或密码错误";
}
@Data
public class PageInfo<T> {/*** 当前页*/private int pageNum;/*** 每页的数量*/private int pageSize;/*** 总记录数*/protected long total;/*** 结果集*/protected List<T> list;/*** 总页数*/private int pages;
}

数据层

entity实体类
@Data
public class User implements Serializable {/*** 用户Id*/private Integer userId;/*** 用户名*/private String userName;/*** 用户状态*/private Integer userState;/*** 用户详情id*/private UserInfo userInfo;private static final long serialVersionUID = 1L;
}
@Data
public class UserInfo implements Serializable {/*** 用户详情id*/private Integer infoId;/*** 家庭住址*/private String address;private static final long serialVersionUID = 1L;
}

mapper接口
public interface UserMapper {/**查询用户列表*/List<User> selectList();/**查询总记录数*/int countTotal();/**分页查询数据*/List<User> selectPage(@Param("start") int start,@Param("pageSize") Integer pageSize);/**通过Id查询用户信息*/User selectUserById(Integer userId);/**添加用户信息*/int insert(User user);/**批量删除用户*/int deleteUsers(Integer[] ids);
}

mapper.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.yaorange.mapper.UserMapper"><resultMap id="BaseResultMap" type="com.yaorange.entity.User"><id property="userId" column="user_id" jdbcType="INTEGER"/><result property="userName" column="user_name" jdbcType="VARCHAR"/><result property="userState" column="user_state" jdbcType="VARCHAR"/></resultMap><resultMap id="User_UserInfo" type="com.yaorange.entity.User" extends="BaseResultMap"><association property="userInfo" javaType="com.yaorange.entity.UserInfo"><id property="infoId" column="user_info_id" jdbcType="INTEGER"/><result property="address" column="address" jdbcType="VARCHAR"/></association></resultMap><sql id="Base_Column_List">user_id,user_name,user_state,user_info_id</sql><insert id="insert" parameterType="com.yaorange.entity.User">INSERT INTO `ssm`.`user`( `user_name`, `user_state`, `user_info_id`)VALUES ( #{userName}, #{userState}, #{userInfo.infoId});</insert><delete id="deleteUsers">update user set user.user_state=1<where>user_id in<foreach collection="array" separator="," open="(" close=")" item="e">#{e}</foreach></where></delete><select id="selectList" resultMap="User_UserInfo">SELECTu.user_id,u.user_name,u.user_state,u.user_info_id,i.addressFROMuser AS u left joinuser_info AS ion u.user_info_id=i.info_idwhere u.user_state=0</select><select id="countTotal" resultType="java.lang.Integer">select Count(*) from user where user_state=0</select><select id="selectPage" resultMap="User_UserInfo">SELECTu.user_id,u.user_name,u.user_state,u.user_info_id,i.addressFROMuser AS u left joinuser_info AS ion u.user_info_id=i.info_idwhere u.user_state=0limit #{start},#{pageSize}</select><select id="selectUserById" resultMap="User_UserInfo">SELECTu.user_id,u.user_name,u.user_state,u.user_info_id,i.addressFROMuser AS u left joinuser_info AS ion u.user_info_id=i.info_idwhere u.user_state=0and u.user_id=#{userId}</select></mapper>

业务层

业务层接口
public interface UserService {/**查询用户列表数据*/List<User> selectList();/**分页查询用户数据*/PageInfo<User> page(Integer pageNum, Integer pageSize);User selectUserById(Integer userId);int insertUser(User user);int deleteUsers(Integer[] ids);
}
业务层实现类
@Service
@Transactional(rollbackFor = Exception.class)
public class UserServiceImpl implements UserService {@Autowiredprivate UserMapper userMapper;@Overridepublic List<User> selectList() {return userMapper.selectList();}@Overridepublic PageInfo<User> page(Integer pageNum, Integer pageSize) {//查询总条数int total=userMapper.countTotal();//总页数int pages=total%pageSize==0?total/pageSize:total/pageSize+1;//起始页int start=(pageNum-1)*pageSize;List<User> userList=userMapper.selectPage(start,pageSize);PageInfo<User> userPageInfo = new PageInfo<>();userPageInfo.setPageNum(pageNum);userPageInfo.setPageSize(pageSize);userPageInfo.setTotal(total);userPageInfo.setList(userList);userPageInfo.setPages(pages);return userPageInfo;}@Overridepublic User selectUserById(Integer userId) {return userMapper.selectUserById(userId);}@Overridepublic int insertUser(User user) {return userMapper.insert(user);}@Overridepublic int deleteUsers(Integer[] ids) {return userMapper.deleteUsers(ids);}}

控制层

@Controller
@ResponseBody
@RequestMapping("/user")
public class UserController {@Autowiredprivate UserService userService;@RequestMapping(value="/list",method = RequestMethod.GET)public Result<?> list(){List<User> userList =userService.selectList();return Result.ok(userList);}@RequestMapping(value = "/page",method = RequestMethod.GET)public Result<?> page(@RequestParam(defaultValue = "1") Integer pageNum,@RequestParam(defaultValue = "3") Integer pageSize){PageInfo<User> userPageInfo=userService.page(pageNum,pageSize);return Result.ok(userPageInfo);}@RequestMapping(method = RequestMethod.GET)public Result<?> selectUserById(@RequestParam Integer userId){User user=userService.selectUserById(userId);return Result.ok(user);}@RequestMapping(value="/add",method = RequestMethod.POST)public Result<?> addUser(@RequestBody  User user){int row=userService.insertUser(user);if(row>0){return Result.ok(CommonConstant.OK_MSG);}return Result.error(CommonConstant.ERROR_MSG);}@RequestMapping(value="/batchDelete",method=RequestMethod.POST)public Result<?> deleteUsers(@RequestBody Integer ids[]){int rows=userService.deleteUsers(ids);if(rows>0){return Result.ok(CommonConstant.OK_MSG);}return Result.error(CommonConstant.ERROR_MSG);}
}

数据层测试代码

@RunWith(SpringRunner.class)
@SpringBootTest
public class UserServiceImplTest {@Autowiredprivate UserService userService;@Testpublic void selectList() {List<User> users = userService.selectList();users.stream().forEach(System.out::println);}@Testpublic void page() {PageInfo<User> pageList = userService.page(1, 10);System.out.println(pageList);}@Testpublic void selectUserById() {User user = userService.selectUserById(2);System.out.println(user);}@Testpublic void insertUser() {User user = new User();user.setUserName("陈六");user.setUserState(1);UserInfo userInfo = new UserInfo();userInfo.setInfoId(2);user.setUserInfo(userInfo);int i = userService.insertUser(user);System.out.println(i);}@Testpublic void deleteUsers() {Integer[] ids={1,5};int i = userService.deleteUsers(ids);System.out.println(i);}
}

Postman测试结果

批量删除

查询用户列表

根据id查用户

添加用户

相关文章:

基于SpringBoot的SSM整合案例

项目目录: 数据库表以及表结构 user表结构 user_info表结构 引入依赖 父模块依赖: <parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.2.12.RELEASE</version>…...

[SS]语义分割_转置卷积

转置卷积&#xff08;Transposed Convolution&#xff09; 抽丝剥茧&#xff0c;带你理解转置卷积&#xff08;反卷积&#xff09; 目录 一、概念 1、定义 2、运算步骤 二、常见参数 一、概念 1、定义 转置卷积&#xff08;Transposed Convolution&#xff09;&#xf…...

面板小程序命令行工具介绍

Ray 体系提供配套的工程化解决方案。 由于多端构建的一些客观原因&#xff0c;在构建流程的设计上&#xff0c;必须将工程套件安装在项目内。 项目内的依赖至少包含以下内容&#xff1a; {"dependencies": {"ray-js/ray": "latest"},"de…...

DBA技术栈MongoDB: 数据增改删除

该博文主要介绍mongoDB对文档数据的增加、更新、删除操作。 1.插入数据 以下案例演示了插入单个文档、多个文档、指定_id、指定多个索引以及插入大量文档的情况。在实际使用中&#xff0c;根据需求选择适合的插入方式。 案例1&#xff1a;插入单个文档 db.visitor.insert({…...

Xcode查看APP文件目录

一、连接真机到MAC电脑上 二、打开Devices 点击window -> Devices and Simulatores 三、选中设备、选择app 四、选择下载内容 五、查看文件内容 得到的文件 右键显示包内容&#xff0c;获得APP内数据 六、分发证书无法下载 使用分发的证书无法下载文件内容&#xf…...

【视频媒体】深入了解直播视频流

深入了解直播视频流&#x1f3a5; YouTube、TikTok live和Twitch上的直播视频是如何工作的&#xff1f; 直播视频流与常规流媒体不同&#xff0c;因为视频内容通过互联网近乎实时发送&#xff0c;通常只有几秒钟的延迟。 下图解释了实现这一目标背后所发生的事情。 步骤1&…...

【01】mapbox js api加载arcgis切片服务

需求&#xff1a; 第三方的mapbox js api加载arcgis切片服务&#xff0c;同时叠加在天地图上&#xff0c;天地图坐标系web墨卡托。 效果图&#xff1a; 形如这种地址去加载http://zjq2022.gis.com:8080/demo/loadmapboxtdt.html 思路&#xff1a; 需要制作一个和天地图比例…...

图像分割实战-系列教程15:deeplabV3+ VOC分割实战3-------网络结构1

&#x1f341;&#x1f341;&#x1f341;图像分割实战-系列教程 总目录 有任何问题欢迎在下面留言 本篇文章的代码运行界面均在Pycharm中进行 本篇文章配套的代码资源已经上传 deeplab系列算法概述 deeplabV3 VOC分割实战1 deeplabV3 VOC分割实战2 deeplabV3 VOC分割实战3 dee…...

【Docker】安装nacos以及实现负载均衡

&#x1f973;&#x1f973;Welcome 的Huihuis Code World ! !&#x1f973;&#x1f973; 接下来看看由辉辉所写的关于Docker的相关操作吧 目录 &#x1f973;&#x1f973;Welcome 的Huihuis Code World ! !&#x1f973;&#x1f973; 前言 一.nacos单个部署 1.镜像拉取 …...

如何用数据赋能社媒营销决策?

在数字化时代&#xff0c;越来越多的商家开始意识到数据分析对于改善经营的重要性。 传统决策更多依赖过往经验、商业直觉、他人的思路模板等方法&#xff0c;或者依靠描述性统计、简单的数据分析。在数字时代&#xff0c;则通过精细化数据分析&#xff0c;做出更明智的营销决策…...

初识k8s(概述、原理、安装)

文章目录 概述由来主要功能 K8S架构架构图组件说明ClusterMasterNodekubectl 组件处理流程 K8S概念组成PodPod控制器ReplicationController&#xff08;副本控制器&#xff09;ReplicaSet &#xff08;副本集&#xff09;DeploymentStatefulSet &#xff08;有状态副本集&#…...

【Java】Maven的基本使用

Maven的基本使用 Maven常用命令 complie&#xff1a;编译clean&#xff1a;清理test&#xff1a;测试package&#xff1a;打包install&#xff1a;安装 mvn complie mvn clean mvn test mvn package mvn installMaven生命周期 IDEA配置Maven Maven坐标 什么是坐标&#xff1f;…...

【RT-DETR有效改进】遥感旋转网络 | LSKNet动态的空间感受野网络(轻量又提点)

前言 大家好&#xff0c;我是Snu77&#xff0c;这里是RT-DETR有效涨点专栏。 本专栏的内容为根据ultralytics版本的RT-DETR进行改进&#xff0c;内容持续更新&#xff0c;每周更新文章数量3-10篇。 专栏以ResNet18、ResNet50为基础修改版本&#xff0c;同时修改内容也支持Re…...

【进阶之路】如何提升 Java 编程内力?

如何提升 Java 编程内力&#xff1f; 可能很多初学者在学完 SpringBoot 之后&#xff0c;做了 1-2 个项目之后&#xff0c;不知道该去学习什么了&#xff0c;其实这时候需要去学习的东西还有很多&#xff0c;接下来我会列举一下主要需要从哪些方面来对 Java 编程深入学习&#…...

Git一台电脑 配置多个账号

Git一台电脑 配置多个账号 Git一台电脑 配置多个账号 常用的Git版本管理有 gitee github gitlab codeup &#xff0c;每个都有独立账号&#xff0c;经常需要在一个电脑上向多个代码仓提交后者更新代码&#xff0c;本文以ssh 方式为例配置 1 对应账号 公私钥生成 建议&#…...

2024年华为OD机试真题-素数之积-Java-OD统一考试(C卷)

题目描述: RSA加密算法在网络安全世界中无处不在,它利用了极大整数因数分解的困难度,数据越大,安全系数越高,给定一个32位正整数,请对其进行因数分解,找出是哪两个素数的乘积。 输入描述: 一个正整数num 0 < num <= 2147483647 输出描述: 如果成功找到,以单个空…...

汤姆·齐格弗里德《纳什均衡与博弈论》笔记(2)

第三章 纳什均衡——博弈论的基础 冯诺伊曼没有解决的问题 博弈论在其建立初始也显现出了严重的局限性。冯诺伊曼解决了二人零和博弈&#xff0c;但对多人博弈问题仍无法解决。如果只是鲁宾逊克鲁索和星期五玩游戏&#xff0c;博弈论可以很好地被应用&#xff0c;但它无法精确…...

QT上位机开发(动态数据采集与监控)

【 声明:版权所有,欢迎转载,请勿用于商业用途。 联系信箱:feixiaoxing @163.com】 上位机开发中,有一种类型的应用软件很特殊,它几乎没有什么交互操作,主要的工作就是检测和显示。如果说在此基础上有什么扩展的话,可能就是安全监控和报警。所以,这个上位机软件…...

vue2 -- 截图工具html2canvas

文章目录 🍉需求描述🍉基础功能实现🍉下载另存为本地图片功能🍉需求描述 可以将网页中的指定元素或整个页面截取为图片,以便保存或分享。 🍉基础功能实现 在 Vue 中使用 html2canvas 实现 1:安装 html2canvas 库。你可以使用 npm 安装,命令如下: npm install …...

笔记-孙子兵法-第三篇-谋攻(1)-不战而屈人之兵,上兵伐谋,韩信之死

笔记-From 《华杉讲透孙子兵法》和《兵以诈立&#xff0c;我读孙子》 第三篇-谋攻&#xff08;1&#xff09;不战而屈人之兵 《孙子兵法》第一篇讲计&#xff0c;第二篇讲野战&#xff0c;第三篇就讲攻城。 《孙子》尚谋&#xff0c;认为最好是“不战而屈人之兵”&#xff0…...

【杂谈】-递归进化:人工智能的自我改进与监管挑战

递归进化&#xff1a;人工智能的自我改进与监管挑战 文章目录 递归进化&#xff1a;人工智能的自我改进与监管挑战1、自我改进型人工智能的崛起2、人工智能如何挑战人类监管&#xff1f;3、确保人工智能受控的策略4、人类在人工智能发展中的角色5、平衡自主性与控制力6、总结与…...

Redis相关知识总结(缓存雪崩,缓存穿透,缓存击穿,Redis实现分布式锁,如何保持数据库和缓存一致)

文章目录 1.什么是Redis&#xff1f;2.为什么要使用redis作为mysql的缓存&#xff1f;3.什么是缓存雪崩、缓存穿透、缓存击穿&#xff1f;3.1缓存雪崩3.1.1 大量缓存同时过期3.1.2 Redis宕机 3.2 缓存击穿3.3 缓存穿透3.4 总结 4. 数据库和缓存如何保持一致性5. Redis实现分布式…...

《Playwright:微软的自动化测试工具详解》

Playwright 简介:声明内容来自网络&#xff0c;将内容拼接整理出来的文档 Playwright 是微软开发的自动化测试工具&#xff0c;支持 Chrome、Firefox、Safari 等主流浏览器&#xff0c;提供多语言 API&#xff08;Python、JavaScript、Java、.NET&#xff09;。它的特点包括&a…...

为什么需要建设工程项目管理?工程项目管理有哪些亮点功能?

在建筑行业&#xff0c;项目管理的重要性不言而喻。随着工程规模的扩大、技术复杂度的提升&#xff0c;传统的管理模式已经难以满足现代工程的需求。过去&#xff0c;许多企业依赖手工记录、口头沟通和分散的信息管理&#xff0c;导致效率低下、成本失控、风险频发。例如&#…...

【2025年】解决Burpsuite抓不到https包的问题

环境&#xff1a;windows11 burpsuite:2025.5 在抓取https网站时&#xff0c;burpsuite抓取不到https数据包&#xff0c;只显示&#xff1a; 解决该问题只需如下三个步骤&#xff1a; 1、浏览器中访问 http://burp 2、下载 CA certificate 证书 3、在设置--隐私与安全--…...

rnn判断string中第一次出现a的下标

# coding:utf8 import torch import torch.nn as nn import numpy as np import random import json""" 基于pytorch的网络编写 实现一个RNN网络完成多分类任务 判断字符 a 第一次出现在字符串中的位置 """class TorchModel(nn.Module):def __in…...

服务器--宝塔命令

一、宝塔面板安装命令 ⚠️ 必须使用 root 用户 或 sudo 权限执行&#xff01; sudo su - 1. CentOS 系统&#xff1a; yum install -y wget && wget -O install.sh http://download.bt.cn/install/install_6.0.sh && sh install.sh2. Ubuntu / Debian 系统…...

技术栈RabbitMq的介绍和使用

目录 1. 什么是消息队列&#xff1f;2. 消息队列的优点3. RabbitMQ 消息队列概述4. RabbitMQ 安装5. Exchange 四种类型5.1 direct 精准匹配5.2 fanout 广播5.3 topic 正则匹配 6. RabbitMQ 队列模式6.1 简单队列模式6.2 工作队列模式6.3 发布/订阅模式6.4 路由模式6.5 主题模式…...

DingDing机器人群消息推送

文章目录 1 新建机器人2 API文档说明3 代码编写 1 新建机器人 点击群设置 下滑到群管理的机器人&#xff0c;点击进入 添加机器人 选择自定义Webhook服务 点击添加 设置安全设置&#xff0c;详见说明文档 成功后&#xff0c;记录Webhook 2 API文档说明 点击设置说明 查看自…...

Golang——6、指针和结构体

指针和结构体 1、指针1.1、指针地址和指针类型1.2、指针取值1.3、new和make 2、结构体2.1、type关键字的使用2.2、结构体的定义和初始化2.3、结构体方法和接收者2.4、给任意类型添加方法2.5、结构体的匿名字段2.6、嵌套结构体2.7、嵌套匿名结构体2.8、结构体的继承 3、结构体与…...