Spring Boot + MyBatis-Plus 项目目录结构
以下是一个标准的 Spring Boot + MyBatis-Plus 项目目录结构及文件命名规范,包含每个目录和文件的作用说明,适用于中大型项目开发:
项目根目录结构
src/
├── main/
│ ├── java/ # Java 源代码
│ │ └── com/example/ # 项目包根目录(根据公司域名定义)
│ │ ├── common/ # 通用模块(全局常量、工具类等)
│ │ ├── config/ # 配置类(数据源、MyBatis-Plus 插件等)
│ │ ├── controller/ # 控制器层(REST API)
│ │ ├── entity/ # 实体类(对应数据库表)
│ │ ├── mapper/ # Mapper 接口(继承 BaseMapper)
│ │ ├── service/ # 服务层接口
│ │ ├── service/impl/# 服务层实现类
│ │ ├── dto/ # 数据传输对象(Data Transfer Object)
│ │ ├── vo/ # 视图对象(View Object)
│ │ ├── enums/ # 枚举类
│ │ ├── filter/ # 过滤器(如登录拦截器)
│ │ ├── aspect/ # AOP 切面(日志、事务等)
│ │ └── exception/ # 自定义异常类及全局异常处理
│ │
│ └── resources/ # 资源文件
│ ├── static/ # 静态资源(HTML/CSS/JS)
│ ├── templates/ # 模板文件(如 Thymeleaf)
│ ├── mapper/ # XML 映射文件(可选)
│ ├── application.yml # 主配置文件
│ └── logback-spring.xml # 日志配置
│
└── test/ # 测试代码└── java/└── com/example/├── mapper/ # Mapper 测试└── service/ # Service 测试
关键目录及文件详解
1. src/main/java/com/example
| 目录名 | 作用 | 文件命名规范 |
|---|---|---|
config | 存放 Spring Boot 配置类 | XxxConfig.java(如 MyBatisPlusConfig.java) |
controller | 处理 HTTP 请求,调用 Service 层 | XxxController.java(如 UserController.java) |
entity | 数据库表对应的实体类,使用 MyBatis-Plus 注解(如 @TableName) | Xxx.java(如 User.java) |
mapper | MyBatis-Plus 的 Mapper 接口,继承 BaseMapper<T> | XxxMapper.java(如 UserMapper.java) |
service | 服务层接口(定义业务逻辑) | XxxService.java(如 UserService.java) |
service/impl | 服务层实现类 | XxxServiceImpl.java(如 UserServiceImpl.java) |
dto | 数据传输对象(用于接口参数或返回结果) | XxxDTO.java(如 UserDTO.java) |
vo | 视图对象(用于前端展示的定制化数据) | XxxVO.java(如 UserVO.java) |
enums | 枚举类(状态码、类型等) | XxxEnum.java(如 ResultCodeEnum.java) |
exception | 自定义异常类及全局异常处理器 | XxxException.java(如 BusinessException.java) |
2. src/main/resources
| 目录/文件名 | 作用 | 文件命名规范 |
|---|---|---|
application.yml | 主配置文件(数据源、MyBatis-Plus 配置等) | 无 |
mapper/*.xml | MyBatis XML 映射文件(非必须,复杂 SQL 时使用) | XxxMapper.xml(如 UserMapper.xml) |
static/ | 静态资源(HTML/CSS/JS/图片) | 无 |
templates/ | 模板文件(如 Thymeleaf、Freemarker) | 无 |
logback-spring.xml | 日志配置文件 | 无 |
配置文件示例
application.yml
spring:datasource:url: jdbc:mysql://localhost:3306/mydb?useSSL=false&serverTimezone=UTCusername: rootpassword: 123456driver-class-name: com.mysql.cj.jdbc.Drivermybatis-plus:configuration:map-underscore-to-camel-case: true # 开启驼峰命名映射global-config:db-config:id-type: auto # 主键自增mapper-locations: classpath:mapper/*.xml # XML 映射文件路径(可选)
代码示例
实体类 User.java
@Data
@TableName("user") // 对应数据库表名
public class User {@TableId(type = IdType.AUTO)private Long id;private String name;private Integer age;@TableField(fill = FieldFill.INSERT) // 自动填充创建时间private LocalDateTime createTime;
}
Mapper 接口 UserMapper.java
public interface UserMapper extends BaseMapper<User> {// 自定义方法(可选)@Select("SELECT * FROM user WHERE age > #{age}")List<User> selectByAgeGreaterThan(Integer age);
}
Service 实现类 UserServiceImpl.java
@Service
public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService {@Overridepublic List<User> getUsersByAge(Integer age) {QueryWrapper<User> wrapper = new QueryWrapper<>();wrapper.gt("age", age);return baseMapper.selectList(wrapper);}
}
命名规范总结
- 包名:全小写,层级清晰(如
com.example.project.module)。 - 类名:大驼峰(如
UserController)。 - 接口与实现类:
- 接口:
XxxService.java - 实现类:
XxxServiceImpl.java
- 接口:
- Mapper 接口:
XxxMapper.java - 实体类:
Xxx.java - DTO/VO:
XxxDTO.java、XxxVO.java - 测试类:
XxxTest.java(如UserServiceTest.java)
注意事项
- 避免过度使用 XML:MyBatis-Plus 的
BaseMapper和QueryWrapper已覆盖 90% 的 SQL 场景。 - 统一异常处理:在
exception包下定义全局异常处理器GlobalExceptionHandler.java。 - 分页插件配置:在
config包下添加MyBatisPlusConfig.java配置分页插件。
通过以上结构,项目将具备良好的可维护性和扩展性。
相关文章:
Spring Boot + MyBatis-Plus 项目目录结构
以下是一个标准的 Spring Boot MyBatis-Plus 项目目录结构及文件命名规范,包含每个目录和文件的作用说明,适用于中大型项目开发: 项目根目录结构 src/ ├── main/ │ ├── java/ # Java 源代码 │ │ └── com/…...
Python之变量及简单的数据类型
本文来源于《Python从入门到实践》,自己整理以供工作参考 基本内容 print("Hello Python World!")message "Hello Python world!" print(message)message "Helllo Python Crash Course world!" print(message)name "ada lov…...
力扣 Hot 100 刷题记录 - 翻转二叉树
力扣 Hot 100 刷题记录 - 翻转二叉树 题目描述 翻转二叉树 是力扣 Hot 100 中的一道经典题目,题目要求如下: 给你一棵二叉树的根节点 root,翻转这棵二叉树,并返回其根节点。 示例 1: 输入:root [4,2,7…...
力扣215.数组中的第K个最大元素--堆排序法(java)
为了找到数组中第K个最大的元素,我们可以使用堆排序的方法。堆排序的核心是构建一个最大堆,并通过多次交换堆顶元素来找到前K个最大的元素。具体步骤如下: 方法思路 构建最大堆:将输入数组转换为最大堆,使得每个父节…...
MySQL增删改查操作 -- CRUD
个人主页:顾漂亮 目录 1.CRUD简介 2.Create新增 使用示例: 注意点: 3.Retrieve检索 使用示例: 注意点: 4.where条件查询 前置知识:-- 运算符 比较运算符 使用示例: 注意点…...
【算法day9】回文数-给你一个整数 x ,如果 x 是一个回文整数,返回 true ;否则,返回 false 。
回文数 给你一个整数 x ,如果 x 是一个回文整数,返回 true ;否则,返回 false 。 回文数是指正序(从左向右)和倒序(从右向左)读都是一样的整数。 例如,121 是回文&#…...
RSA混合加密RSA混合加密
RSA混合加密是一种结合非对称加密(RSA)和对称加密(AES)的技术,通过两者的优势互补,实现高效且安全的数据传输。以下是详细解释和示例: RSA混合加密的核心原理 非对称加密(RSA&#x…...
蛋白质功能预测论文阅读记录2025(DPFunc、ProtCLIP)
前言 最近研究到瓶颈了,怎么优化都提升不了,遂开始看点最新的论文。 DPFunc 2025.1.2 Nature Communication 中南大学 论文地址:DPFunc: accurately predicting protein function via deep learning with domain-guided structure inform…...
Linux网络套接字编程——UDP服务器
Linux网络套接字编程——创建并绑定-CSDN博客 前面已经介绍了网络套接字的创建和绑定,这篇文章会通过UDP套接字实现一个UDP服务器。 先介绍将使用的接口。 recvfrom ssize_t recvfrom(int sockfd, void *buf, size_t len, int flags,struct sockaddr *src_addr,…...
主流向量数据库对比
在 AI 的 RAG(检索增强生成)研发领域,向量数据库是存储和查询向量嵌入的核心工具,用于支持高效的语义搜索和信息检索。向量嵌入是文本或其他非结构化数据的数值表示,RAG 系统通过这些嵌入从知识库中检索相关信息&#…...
54.HarmonyOS NEXT 登录模块开发教程(八):测试与调试技巧
温馨提示:本篇博客的详细代码已发布到 git : https://gitcode.com/nutpi/HarmonyosNext 可以下载运行哦! HarmonyOS NEXT 登录模块开发教程(八):测试与调试技巧 文章目录 HarmonyOS NEXT 登录模块开发教程(…...
Vue3中 ref 与 reactive区别
ref 用途: ref 通常用于创建一个响应式的基本类型数据(如 string、number、boolean 等),但它也可以用于对象或数组 返回值: ref 返回一个带有 .value 属性的对象,访问或修改数据需要通过 .value 进行 使用场景: …...
结构型——装饰器模式
装饰器模式 装饰器是指能动态地为对象添加额外的功能的一种结构型设计模式。 特点 不修改原有代码的情况下,动态地扩展一个对象的功能。支持多个装饰器叠加使用透明性,装饰后的对象与原对象保持一致,客户端无需感知装饰过程 结构模式与实…...
在Simulink中将Excel数据导入可变负载模块的方法介绍
文章目录 数据准备与格式要求Excel数据格式MATLAB预处理数据导入方法使用From Spreadsheet模块(直接导入Excel)通过MATLAB工作区中转(From Workspace模块)使用1-D Lookup Table模块(非线性负载映射)Signal Builder模块(变载工况导入)可变负载模块配置注意事项与调试在S…...
分布式事务的产生背景及理论指导
分布式事务的产生背景 在现代互联网和企业级系统架构中,随着业务需求的增长,单体架构逐渐向微服务架构、分布式架构演进。传统单体架构下,事务管理相对简单,可以依赖数据库的本地事务(如 MySQL 的 ACID 事务ÿ…...
动手学强化学习-记录
3.5 蒙特卡洛方法 统计每一个状态s出现的总次数和总回报,用大数定律,总回报/总次数≈状态s的期望回报 第4章 动态规划算法 策略迭代中的策略评估使用贝尔曼期望方程来得到一个策略的状态价值函数,这是一个动 态规划的过程;而价值迭代直接使用贝尔曼最…...
RocketMQ性能优化篇
在分布式消息系统中,RocketMQ以其高性能、高可靠性和高可扩展性而被广泛应用。然而,为了充分发挥其性能优势,需要进行一系列的性能测试和优化。本文将从性能测试方法和优化实践两个方面,详细介绍如何对RocketMQ进行性能优化。通过…...
C语言为例谈数据依赖性
数据依赖性(Data Dependency)是指程序中后续操作的计算结果或内存访问依赖于前面操作的结果。在存在数据依赖的情况下,编译器或处理器会保证这些操作的执行顺序,因此不需要显式地使用内存屏障(Memory Barrierÿ…...
阿里云操作系统控制台评测:国产AI+运维 一站式运维管理平台
阿里云操作系统控制台评测:国产AI运维 一站式运维管理平台 引言 随着云计算技术的飞速发展,企业在云端的运维管理面临更高的要求。阿里云操作系统控制台作为一款集运维管理、智能助手和系统诊断等多功能于一体的工具,正逐步成为企业高效管理…...
C++中的const与类型转换艺术
目录 强制转换 static_cast const_cast reinterpret_cast dynamic_cast const关键字 修饰内置类型* 修饰指针类型* 类比 数组指针 指针数组 函数指针 指针函数 强制转换 C语言中的强制转换在C代码中依然可以使用,这种C风格的转换格式非常简单 TYPE a …...
网络安全演练有哪些形式
OPENVAS使用 1、确定指定IP是否能ping通 2、创建扫描目标 3、创建扫描任务(scan management →newtask) 4、开始任务start 5、查看扫描细节 6、查看扫描结果,包含漏洞详细信息,亦可到处PDF文件 7、导出扫描结果报告 8、为…...
c++常用的算术生成算法
注意: 算术生成算法属于小型算法,使用时包含的头文件为 #include <numeric> 算法简介: accumulate //计算容器元素累加总和fill //向容器中添加元素 1. accumulate 功能描述: 计算区间内 容器元素…...
2011. 执行操作后的变量值
执行操作后的变量值 题目描述尝试做法推荐做法 题目描述 存在一种仅支持 4 种操作和 1 个变量 X 的编程语言: X 和 X 使变量 X 的值 加 1 –X 和 X-- 使变量 X 的值 减 1 最初,X 的值是 0 给你一个字符串数组 operations ,这是由操作组成的…...
特辣的海藻!10
基础知识点 1.清除换行符 scan.nextInt()要加scan.nextLine()清楚换行符。 2.Map.Entry<K, V> Map.Entry是Map接口的嵌套接口,表示一个键值对(Key-Value) 常用方法: entry.getKey():获取键 …...
SpringBoot动态加载JAR包实战:实现插件化架构的终极指南
在需要热插拔业务模块、支持灰度发布的系统中,动态加载外部JAR包是提升系统扩展性的核心技术。本文将手把手实现3种动态加载方案,包含可直接运行的SpringBoot代码,并深入分析类加载机制与内存泄漏预防策略。 一、动态加载的应用场景 电商…...
双因素拆解法 - 分析比例型指标的因子贡献度
什么是比例型指标 比例型指标是指那些以比例或比率形式表示的指标,通常涉及两个相关量的比较。以下是一些常见的比例型指标的例子: 毛利率:毛利率是毛利与销售收入的比率,公式为: 毛利率 毛利 销售收入 100 % \tex…...
sqli-lab靶场学习(八)——Less26-28
前言 25关已经出现了初步的一些关键字过滤,通过双写可以绕过。后面的关卡,我们会遇到更多关键字过滤,需要各种技巧绕过。 Less26 第26关写了会过滤空格和注释符。有很多的答案,会用%a0替代空格,但据说这是sqli-labs部…...
Netty基础—4.NIO的使用简介二
大纲 1.Buffer缓冲区 2.Channel通道 3.BIO编程 4.伪异步IO编程 5.改造程序以支持长连接 6.NIO三大核心组件 7.NIO服务端的创建流程 8.NIO客户端的创建流程 9.NIO优点总结 10.NIO问题总结 4.伪异步IO编程 (1)BIO的主要问题 (2)BIO编程模型的改进 (3)伪异步IO编程 …...
双指针算法专题之——复写零
文章目录 题目介绍思路分析异地复写优化为就地复写 AC代码 题目介绍 链接: 1089. 复写零 思路分析 那么这道题我们依然可以使用双指针算法来解决 异地复写 先不考虑题目的要求,直接就地在原数组上修改,可能不太好想,我们这里可以先在一个…...
【Pandas】pandas Series last_valid_index
Pandas2.2 Series Time Series-related 方法描述Series.asfreq(freq[, method, how, …])用于将时间序列数据转换为指定的频率Series.asof(where[, subset])用于返回时间序列中指定索引位置的最近一个非缺失值Series.shift([periods, freq, axis, …])用于将时间序列数据沿指…...
