写一个部门管理,按controller,service,mapper三层架构写

时间: 2025-03-21 07:01:21 浏览: 7

好的,用户让我用中文回答如何写一个部门管理模块,按照controller、service、mapper三层架构来写。我需要先理解用户的需求。用户可能正在开发一个企业级的应用,需要管理组织结构,部门管理是常见的功能,包括增删改查等操作。用户提到三层架构,说明他希望代码结构清晰,符合常见的Spring框架规范。

首先,我需要确认用户的技术栈,可能使用的是Spring Boot,结合MyBatis或者JPA。根据用户之前的提问历史,他曾询问过微信支付的实现,可能对Java和Spring生态比较熟悉。所以我会默认使用Spring Boot和MyBatis-Plus,因为MyBatis-Plus在国内比较流行,能简化CRUD操作。

接下来,我需要分解三层架构的职责。Controller负责处理HTTP请求,Service处理业务逻辑,Mapper(或DAO)负责数据库交互。需要确保每层之间的调用关系正确,比如Controller调用Service,Service调用Mapper。

然后,考虑部门管理的核心功能。通常包括添加部门、删除部门、修改部门信息、查询部门列表、获取部门详情等。所以需要设计对应的RESTful API,比如POST /depts,DELETE /depts/{id},PUT /depts/{id},GET /depts等。

在实体类设计方面,部门通常有ID、名称、父部门ID、排序号、状态等字段。需要创建对应的Department实体类,并使用MyBatis-Plus的注解来映射数据库表。

对于Mapper层,使用MyBatis-Plus的BaseMapper可以快速实现基本的CRUD方法,无需手动编写XML文件,提高效率。Service层需要实现具体的业务逻辑,比如添加部门前检查名称是否重复,删除部门时检查是否存在子部门等。这些业务规则需要明确,并在代码中处理。

Controller层需要处理参数校验,比如使用@Valid注解验证传入的DTO是否符合要求。同时,统一返回格式,比如使用Result类包装响应数据,便于前端处理。

异常处理也是一个重点。在Service层抛出业务异常,比如部门名称重复时抛出异常,然后通过全局异常处理器捕获,返回统一的错误信息。这能提高代码的可维护性。

另外,用户可能需要分页查询部门列表,所以示例中使用了MyBatis-Plus的Page类来实现分页,方便用户扩展。

最后,考虑代码的规范性和最佳实践,比如使用lombok简化代码,合理使用事务注解,以及遵循RESTful设计原则。同时,给出一些扩展建议,比如添加部门负责人、树形结构展示,帮助用户根据实际需求进行后续开发。

总结来说,我需要提供一个结构清晰、符合三层架构的示例代码,并解释各层的职责和关键点,确保用户能够理解并应用到实际项目中。同时,提醒用户注意事务管理、日志记录等细节,确保代码的健壮性和可维护性。以下是基于Spring Boot + MyBatis-Plus实现的部门管理模块完整示例,采用标准的三层架构:

一、项目结构

src/main/java
├── com.example.department
│   ├── controller
│   │   └── DeptController.java       # 控制层
│   ├── service
│   │   ├── DeptService.java          # 服务接口
│   │   └── impl
│   │       └── DeptServiceImpl.java  # 服务实现
│   ├── mapper
│   │   └── DeptMapper.java           # 数据访问层
│   ├── entity
│   │   └── Department.java           # 实体类
│   └── dto
│       └── DeptDTO.java              # 数据传输对象

二、具体实现代码

1. 实体类 (entity/Department.java)

@Data
@TableName("sys_dept")
@AllArgsConstructor
@NoArgsConstructor
public class Department {
    @TableId(type = IdType.AUTO)
    private Long id;
    
    private String deptName;
    private Long parentId;
    private Integer orderNum;
    private Integer status;  // 0-正常 1-停用
    
    @TableField(fill = FieldFill.INSERT)
    private LocalDateTime createTime;
    
    @TableField(fill = FieldFill.INSERT_UPDATE)
    private LocalDateTime updateTime;
}

2. Mapper层 (mapper/DeptMapper.java)

@Mapper
public interface DeptMapper extends BaseMapper<Department> {
    // 自定义查询示例
    @Select("SELECT * FROM sys_dept WHERE parent_id = #{parentId}")
    List<Department> selectByParentId(Long parentId);
}

3. Service层 (service/DeptService.java)

public interface DeptService extends IService<Department> {
    List<Department> getDeptTree();
    boolean addDept(DeptDTO deptDTO);
    boolean updateDeptStatus(Long id, Integer status);
}

4. Service实现 (service/impl/DeptServiceImpl.java)

@Service
@Slf4j
public class DeptServiceImpl extends ServiceImpl<DeptMapper, Department> implements DeptService {

    @Override
    public List<Department> getDeptTree() {
        List<Department> allDepts = baseMapper.selectList(null);
        return buildDeptTree(0L, allDepts); // 从根节点(0)开始构建
    }

    private List<Department> buildDeptTree(Long parentId, List<Department> allDepts) {
        return allDepts.stream()
                .filter(dept -> dept.getParentId().equals(parentId))
                .peek(dept -> dept.setChildren(buildDeptTree(dept.getId(), allDepts)))
                .collect(Collectors.toList());
    }

    @Override
    @Transactional
    public boolean addDept(DeptDTO deptDTO) {
        // 检查部门名称是否重复
        Long count = lambdaQuery()
                .eq(Department::getDeptName, deptDTO.getDeptName())
                .count();
        if (count > 0) {
            throw new BusinessException("部门名称已存在");
        }

        Department dept = new Department();
        BeanUtils.copyProperties(deptDTO, dept);
        return save(dept);
    }

    @Override
    public boolean updateDeptStatus(Long id, Integer status) {
        return lambdaUpdate()
                .eq(Department::getId, id)
                .set(Department::getStatus, status)
                .update();
    }
}

5. Controller层 (controller/DeptController.java)

@RestController
@RequestMapping("/dept")
@RequiredArgsConstructor
public class DeptController {
    private final DeptService deptService;

    @GetMapping("/tree")
    public Result<List<Department>> getDeptTree() {
        return Result.success(deptService.getDeptTree());
    }

    @PostMapping
    public Result<Boolean> addDept(@Valid @RequestBody DeptDTO deptDTO) {
        return Result.success(deptService.addDept(deptDTO));
    }

    @PutMapping("/{id}/status")
    public Result<Boolean> updateStatus(@PathVariable Long id, 
                                      @RequestParam Integer status) {
        return Result.success(deptService.updateDeptStatus(id, status));
    }

    @DeleteMapping("/{id}")
    public Result<Boolean> deleteDept(@PathVariable Long id) {
        // 删除前校验是否存在子部门
        Long count = deptService.lambdaQuery()
                .eq(Department::getParentId, id)
                .count();
        if (count > 0) {
            throw new BusinessException("存在子部门,无法删除");
        }
        return Result.success(deptService.removeById(id));
    }
}

三、辅助类说明

1. 统一返回格式 (Result.java)

@Data
@NoArgsConstructor
@AllArgsConstructor
public class Result<T> {
    private Integer code;
    private String msg;
    private T data;

    public static <T> Result<T> success(T data) {
        return new Result<>(200, "成功", data);
    }
}

2. DTO对象 (dto/DeptDTO.java)

@Data
public class DeptDTO {
    @NotBlank(message = "部门名称不能为空")
    private String deptName;
    
    @NotNull
    private Long parentId;
    
    @Min(0)
    private Integer orderNum;
}

四、关键实现细节

  1. 树形结构构建

    • 使用递归算法实现部门树
    • 前端可通过children属性渲染树形组件
  2. 事务控制

    • @Transactional注解保证数据库操作的原子性
    • 在删除部门时进行存在性校验
  3. 参数校验

    • 使用@Valid进行DTO参数校验
    • 自定义业务异常BusinessException
  4. MyBatis-Plus特性

    • 自动填充时间字段(需配置MetaObjectHandler
    • 使用LambdaQueryWrapper进行类型安全查询

五、扩展建议

  1. 权限控制

    @PreAuthorize("hasRole('ADMIN')") // 在Controller方法上添加权限控制
    
  2. 日志记录

    @Slf4j
    public class DeptServiceImpl {
        public boolean addDept(...) {
            log.info("新增部门:{}", deptDTO);
        }
    }
    
  3. 分页查询

    @GetMapping("/page")
    public Result<Page<Department>> getDeptPage(
        @RequestParam(defaultValue = "1") Integer pageNum,
        @RequestParam(defaultValue = "10") Integer pageSize) {
        Page<Department> page = new Page<>(pageNum, pageSize);
        return Result.success(deptService.page(page));
    }
    

完整实现需要配合数据库表创建(示例SQL):

CREATE TABLE sys_dept (
    id BIGINT PRIMARY KEY AUTO_INCREMENT,
    dept_name VARCHAR(50) NOT NULL,
    parent_id BIGINT DEFAULT 0,
    order_num INT DEFAULT 0,
    status TINYINT DEFAULT 0,
    create_time DATETIME,
    update_time DATETIME
);

建议根据实际需求扩展以下功能:

  1. 部门负责人关联
  2. 部门层级路径存储(如1.2.3)
  3. 部门人数统计
  4. 部门转移合并功能
向AI提问 loading 发送消息图标

相关推荐

大家在看

recommend-type

基于Matlab绘制风向与风速的关系图.zip.zip

1.版本:matlab2014/2019a,内含运行结果,不会运行可私信 2.领域:智能优化算法、神经网络预测、信号处理、元胞自动机、图像处理、路径规划、无人机等多种领域的Matlab仿真,更多内容可点击博主头像 3.内容:标题所示,对于介绍可点击主页搜索博客 4.适合人群:本科,硕士等教研学习使用 5.博客介绍:热爱科研的Matlab仿真开发者,修心和技术同步精进,matlab项目合作可si信
recommend-type

基于时空图卷积(ST-GCN)的骨骼动作识别(python源码+项目说明)高分项目

基于时空图卷积(ST-GCN)的骨骼动作识别(python源码+项目说明)高分项目,含有代码注释,新手也可看懂,个人手打98分项目,导师非常认可的高分项目,毕业设计、期末大作业和课程设计高分必看,下载下来,简单部署,就可以使用。 基于时空图卷积(ST-GCN)的骨骼动作识别(python源码+项目说明)高分项目 基于时空图卷积(ST-GCN)的骨骼动作识别(python源码+项目说明)高分项目 基于时空图卷积(ST-GCN)的骨骼动作识别(python源码+项目说明)高分项目 基于时空图卷积(ST-GCN)的骨骼动作识别(python源码+项目说明)高分项目 基于时空图卷积(ST-GCN)的骨骼动作识别(python源码+项目说明)高分项目基于时空图卷积(ST-GCN)的骨骼动作识别(python源码+项目说明)高分项目基于时空图卷积(ST-GCN)的骨骼动作识别(python源码+项目说明)高分项目基于时空图卷积(ST-GCN)的骨骼动作识别(python源码+项目说明)高分项目基于时空图卷积(ST-GCN)的骨骼动作识别(python源码+项目说明)高分项目基于时空图卷积(ST
recommend-type

毕业设计C++语言实现基于QT的仿宝石迷阵游戏项目源码.zip

毕业设计C++语言实现基于QT的仿宝石迷阵游戏项目源码,也可作为期末大作业。 本次项目我们使用C++语言,实现了基于QT的仿宝石迷阵游戏,并且接入数据库实现了登录注册和根据最高分排行的功能,为了优化用户体验,在设置界面提供声音、亮度的调整滑块和打开帮助文档以及网站的接口。在游戏性方面,点击主界面的“start”按钮,可以根据自身要求选择三种难度,游戏界面消除方块的种类会随着难度上调而增加,并且在游戏界面提供暂停、提示、返回主菜单的接口,引入“魔法方块”来增加游戏性和可玩性。 菜单界面提供查看排行榜,开始游戏,设置接口,注册,登录,退出 设置难度选择界面,提供三种难度的选择 游戏界面 游戏界面右侧为宝石棋盘,棋盘下侧为时间条,时间条归零则游戏结束 点击棋盘任意两个相邻的宝石则可以交换它们,若交换后存在至少三个相邻的相同宝石,则消去它们,同时增加相应分数,同时消除越多的宝石得分越高 如果同时消去的宝石大于三个,会根据同时校区宝石个数不同形成不同的魔法宝石,魔法宝石拥有特殊的技能,供玩家探索 界面右上角为积分板,可以在这里查看所得的分数 界面右下角为操作按钮,点击MENU返回主菜单
recommend-type

多邻国语言学习 v5.13.4 for Android 英语、日语、韩语、德语…等30余种语言学习应用 .rar

多邻国语言学习 v5.13.4 for Android 英语、日语、韩语、德语…等30余种语言学习应用
recommend-type

FAST FACTORIZED_FFBP论文_FFBP_后向投影.zip

FAST FACTORIZED_FFBP论文_FFBP_后向投影.zip

最新推荐

recommend-type

bytetrack的跟踪效果

dancetrack0004的gt
recommend-type

hiddenite-shops:Minecraft Bukkit商店交易插件

Minecraft 是一款流行的沙盒游戏,允许玩家在虚拟世界中探索、建造和生存。为了增加游戏的可玩性和互动性,开发者们创造了各种插件来扩展游戏的功能。Bukkit 是一个流行的 Minecraft 服务器端插件API,它允许开发人员创建插件来增强服务器的功能。本文将详细介绍一个基于 Bukkit API 的插件——hiddenite-shops,该插件的主要功能是在 Minecraft 游戏中的商店系统中进行商品的买卖。 首先,我们需要了解 Bukkit 是什么。Bukkit 是一款开源的 Minecraft 服务器软件,它允许开发人员利用 Java 编程语言创建插件。这些插件可以修改、增强游戏的玩法或添加新的游戏元素。Bukkit 插件通常托管在各种在线代码托管平台如 GitHub 上,供玩家和服务器运营者下载和安装。 说到 hiddenite-shops 插件,顾名思义,这是一个专注于在 Minecraft 中创建商店系统的插件。通过这个插件,玩家可以创建自己的商店,并在其中摆放出售的商品。同时,玩家也可以在别人的商店中购物。这样的插件极大地丰富了游戏内的交易模式,增加了角色扮演的元素,使游戏体验更加多元化。 在功能方面,hiddenite-shops 插件可能具备以下特点: 1. 商品买卖:玩家可以把自己不需要的物品放置到商店中出售,并且可以设定价格。其他玩家可以购买这些商品,从而促进游戏内的经济流通。 2. 商店管理:每个玩家可以创建属于自己的商店,对其商店进行管理,例如更新商品、调整价格、装饰商店界面等。 3. 货币系统:插件可能包含一个内置的货币系统,允许玩家通过虚拟货币来购买和出售商品。这种货币可能需要玩家通过游戏中的某些行为来获取,比如采矿、钓鱼或完成任务。 4. 权限控制:管理员可以对商店进行监管,设定哪些玩家可以创建商店,或者限制商店的某些功能,以维护游戏服务器的秩序。 5. 交易记录:为了防止诈骗和纠纷,hiddenite-shops 插件可能会记录所有交易的详细信息,包括买卖双方、交易时间和商品详情等。 在技术实现上,hiddenite-shops 插件需要遵循 Bukkit API 的规范,编写相应的 Java 代码来实现上述功能。这涉及到对事件监听器的编程,用于响应游戏内的各种动作和事件。插件的开发人员需要熟悉 Bukkit API、Minecraft 游戏机制以及 Java 编程语言。 在文件名称列表中,提到的 "hiddenite-shops-master" 很可能是插件代码的仓库名称,表示这是一个包含所有相关源代码、文档和资源文件的主版本。"master" 通常指代主分支,是代码的最新且稳定版本。在 GitHub 等代码托管服务上,开发者通常会在 master 分支上维护代码,并将开发中的新特性放在其他分支上,直到足够稳定后再合并到 master。 总的来说,hiddenite-shops 插件是对 Minecraft Bukkit 服务器功能的一个有力补充,它为游戏世界中的经济和角色扮演提供了新的元素,使得玩家之间的交易和互动更加丰富和真实。通过理解和掌握该插件的使用,Minecraft 服务器运营者可以为他们的社区带来更加有趣和复杂的游戏体验。
recommend-type

【SSM框架快速入门】

# 摘要 本文旨在详细介绍SSM(Spring + SpringMVC + MyBatis)框架的基础与高级应用,并通过实战案例分析深入解析其在项目开发中的实际运用。首先,文章对SSM框架进行了概述,随后逐章深入解析了核心组件和高级特性,包括Spring的依赖注入、AOP编程、SpringMVC的工作流程以及MyBatis的数据持久化。接着,文章详细阐述了SSM框架的整合开发基础,项目结构配置,以及开发环境的搭建和调试。在高级应用
recommend-type

项目环境搭建及系统使用说明用例

### Postman 示例 API 项目本地部署教程 对于希望了解如何搭建和使用示例项目的用户来说,可以从以下几个方面入手: #### 环境准备 为了成功完成项目的本地部署,需要按照以下步骤操作。首先,将目标项目 fork 至自己的 GitHub 账户下[^1]。此过程允许开发者拥有独立的代码仓库副本以便于后续修改。 接着,在本地创建一个新的虚拟环境来隔离项目所需的依赖项,并通过 `requirements.txt` 文件安装必要的库文件。具体命令如下所示: ```bash python -m venv my_env source my_env/bin/activate # Linu
recommend-type

Windows Media Encoder 64位双语言版发布

Windows Media Encoder 64位(英文和日文)的知识点涵盖了软件功能、操作界面、编码特性、支持的设备以及API和SDK等方面,以下将对这些内容进行详细解读。 1. 软件功能和应用领域: Windows Media Encoder 64位是一款面向Windows操作系统的媒体编码软件,支持64位系统架构,是Windows Media 9系列中的一部分。该软件的主要功能包括录制和转换视频文件。它能够让用户通过视频捕捉设备或直接从电脑桌面上录制视频,同时提供了丰富的文件格式转换选项。Windows Media Encoder广泛应用于网络现场直播、点播内容的提供以及视频文件的制作。 2. 用户界面和操作向导: 软件提供了一个新的用户界面和向导,旨在使初学者和专业用户都容易上手。通过简化的设置流程和直观的制作指导,用户能够快速设定和制作影片。向导会引导用户选择适当的分辨率、比特率和输出格式等关键参数。 3. 编码特性和技术: Windows Media Encoder 64位引入了新的编码技术,如去隔行(de-interlacing)、逆向电影转换(inverse telecine)和屏幕捕捉,这些技术能够显著提高视频输出的品质。软件支持从最低320x240分辨率60帧每秒(fps)到最高640x480分辨率30fps的视频捕捉。此外,它还能处理最大到30GB大小的文件,这对于长时间视频录制尤其有用。 4. 支持的捕捉设备: Windows Media Encoder 64位支持多种视频捕捉设备,包括但不限于Winnov、ATI、Hauppauge等专业视频捕捉卡,以及USB接口的视频摄像头。这为用户提供了灵活性,可以根据需要选择合适的硬件设备。 5. 高级控制选项和网络集成: Windows Media Encoder SDK是一个重要的组件,它为网站开发者提供了全面的编码控制功能。开发者可以利用它实现从网络(局域网)进行远程控制,或通过API编程接口和ASP(Active Server Pages)进行程序化的控制和管理。这使得Windows Media Encoder能够更好地融入网站和应用程序中,提供了更广阔的使用场景,例如自动化的视频处理流水线。 6. 兼容性和语言版本: 本文件提供的版本是Windows Media Encoder 64位的英文和日文版本。对于需要支持多语言用户界面的场合,这两个版本的软件能够满足不同语言用户的需求。经过测试,这些版本均能正常使用,表明了软件的兼容性和稳定性。 总结来说,Windows Media Encoder 64位(英文和日文)是一款功能强大、易于操作的媒体编码软件。它在操作便捷性、视频编码品质、设备兼容性和程序化控制等方面表现突出,适合用于视频内容的创建、管理和分发。对于需要高质量视频输出和网络集成的用户而言,无论是个人创作者还是专业视频制作团队,该软件都是一种理想的选择。
recommend-type

【IEEE 14总线系统Simulink模型:从零到专家的终极指南】:构建、仿真及故障诊断

# 摘要 本文详细介绍了IEEE 14总线系统的Simulink模型构建、仿真分析以及故障诊断技术。第一章提供了系统概述,为后续章节打下基础。第二章深入探讨了Simulink模型的构建,涵盖了用户界面、工具模块、电路元件、负荷及发电机组建模方法,以及模型的参数化和优化。第三章讲述了如何进行IEEE 14总线系统的仿真以及如
recommend-type

树莓派改中文

### 树莓派修改系统语言为中文教程 要将树莓派的操作系统界面或设置更改为中文,可以按照以下方法操作: #### 方法一:通过图形化界面更改语言 如果已经启用了树莓派的桌面环境并能够正常访问其图形化界面,则可以通过以下方式更改系统语言: 1. 打开 **Preferences(首选项)** 菜单。 2. 进入 **Raspberry Pi Configuration(树莓派配置)** -> **Localisation(本地化)**。 3. 设置 **Change Locale(更改区域设置)** 并选择 `zh_CN.UTF-8` 或其他适合的语言编码[^1]。 完成上述步骤后,重启设
recommend-type

SenseLock精锐IV C# API使用与代码示例教程

根据给定文件信息,我们可以推断出以下知识点: 标题中提到了"SenseLock 精锐IV C# 使用说明及例子",说明此文档是关于SenseLock公司出品的精锐IV产品,使用C#语言开发的API调用方法及相关示例的说明。SenseLock可能是一家专注于安全产品或服务的公司,而精锐IV是其旗下的一款产品,可能是与安全、加密或者硬件锁定相关的技术解决方案。文档可能包含了如何将该技术集成到C#开发的项目中,以及如何使用该技术的详细步骤和代码示例。 描述中提到"SenseLock API调用 测试通过 还有代码 及相关文档",说明文档中不仅有SenseLock产品的C# API调用方法,而且这些方法经过了测试验证,并且提供了相应的代码样例以及相关的技术文档。这表明用户可以通过阅读这份资料来了解如何在C#环境中使用SenseLock提供的API进行软件开发,以及如何在开发过程中解决潜在的问题。 标签为"SenseLock C# API",进一步确认了该文件的内容是关于SenseLock公司提供的C#编程语言接口。标签的作用是作为标识和分类,方便用户根据关键词快速检索到相关的文件。这里的信息提示我们,此文件对于那些希望在C#程序中集成SenseLock技术的开发者来说非常有价值。 压缩包的文件名称列表显示有两个文件:一个是"精锐IV C# 使用.docx",这个文件很可能是一个Word文档,用于提供详细的使用说明和例子,这可能包括精锐IV产品的功能介绍、API接口的详细说明、使用场景、示例代码等;另一个是"32bitdll",这可能是一个32位的动态链接库文件,该文件是C#程序中可以被调用的二进制文件,用于执行特定的API函数。 总结一下,该压缩包文件可能包含以下几个方面的知识点: 1. SenseLock精锐IV产品的概述:介绍产品的功能、特性以及可能的应用场景。 2. C# API接口使用说明:详细解释API的使用方法,包括如何调用特定的API函数,以及每个函数的参数和返回值。 3. API调用示例代码:提供在C#环境中调用SenseLock API的具体代码样例,帮助开发者快速学习和应用。 4. 测试验证信息:说明API调用方法已经通过了哪些测试,保证其可靠性和有效性。 5. 32位动态链接库文件:为C#项目提供必要的可执行代码,用于实现API调用的功能。 该文档对于希望在C#项目中集成SenseLock精锐IV产品的开发者来说,是一份非常有价值的参考资料,能够帮助他们理解如何在软件开发中利用SenseLock提供的技术,并快速实现解决方案。
recommend-type

深入理解PgSQL绿色版:揭秘其优势与五大应用案例

# 摘要 PgSQL绿色版是一种轻量级、易于部署的数据库系统,旨在提供高性能、高稳定性的数据库服务,同时保持环境兼容性和可移植性。本文首先概述了PgSQL绿色版的基本概念,随后详细阐述了其核心优势,包括高效的数据存储结构和并发处理能力、简单的安装与部署流程,以及对多种操作系统的支持。通过分析不同应用场景如Web应用、数据分析、开源项目、嵌入式设备和大数据处理的案例,本文展示了PgS
recommend-type

ubuntu开机pcie bus error刷屏

### Ubuntu 开机 PCIE Bus Error 刷屏问题解决方案 在遇到 Ubuntu 开机时因 `PCIE Bus Error` 导致刷屏的问题时,可以通过调整系统的启动参数来解决问题。以下是具体的解决方法: #### 修改 Grub 文件配置 通过编辑 `/etc/default/grub` 文件中的启动参数可以有效缓解此问题。 1. **进入恢复模式** 如果系统无法正常启动到图形界面,则需要先通过 GRUB 菜单进入恢复模式。按下电源键启动计算机,在 BIOS 自检完成后迅速按住 Shift 键以调出 GRUB 启动菜单。选择带有 `(recovery mode)
手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部