微服务项目->在线oj系统(Java-Spring)--增删改

后端代码

增添

toR

QuestionAddDTO

了解前端添加一个问题需要我们传入什么数据

java 复制代码
package com.bite.system.model.question.DTO;

import lombok.Getter;
import lombok.Setter;

@Getter
@Setter
public class QuestionAddDTO {

    private String title;

    private Integer difficulty;

    private Long timeLimit;

    private Long spaceLimit;

    private String content;

    private String questionCase;

    private String defaultCode;

    private String mainFuc;
}

Controller

复制代码
  @PostMapping("/add")
    public R<Void> add(@RequestBody QuestionAddDTO questionAddDTO){
        return toR(questionService.add(questionAddDTO)) ;
    }

Service

首先通过mapper进行查询,查询我们的数据库里面是否存在相同标题的题目,如果有,抛出异常,然后异常统一捕获,返回给前端报错

如果所增加题目并不在数据库里面,则新创建一个Question对象,然后将我们前端传来参数(DTO)复制给question对象,然后让数据库进行插入操作

java 复制代码
    @Override
    public int add(QuestionAddDTO questionAddDTO) {
        List<Question> list=questionMapper.selectList(new LambdaQueryWrapper<Question>().eq(Question::getTitle,questionAddDTO.getTitle()));
        if(CollectionUtil.isNotEmpty(list)){
            throw new ServiceException(ResultCode.FAILED_ALREADY_EXISTS);
        }
        Question question = new Question();
        BeanUtil.copyProperties(questionAddDTO, question);
        int insert = questionMapper.insert(question);
        return insert;
    }

如果插入成功,新增数据将会出现在我们列表的第一个,否则传给前端错误原因

修改

java 复制代码
@Data
public class QuestionEditDTO extends QuestionAddDTO{

    private Long questionId;
}

当我们点开修改页面的时候,会根据id自动获取到相关的详细内容

java 复制代码
  @GetMapping("/detail")
    public R<QuestionDetailVO> detail(Long questionId) {
        return R.ok(questionService.detail(questionId));
    }

首先通过id进行查询,看是否存在这本书,如果不存在抛出异常

如果数据库中有该题,则从数据库里面查询到数据,然后创建一个返回给前端的VO

java 复制代码
@Data
public class QuestionDetailVO {

    private Long questionId;

    private String title;

    private Integer difficulty;

    private Long timeLimit;

    private Long spaceLimit;

    private String content;

    private String questionCase;

    private String defaultCode;

    private String mainFuc;
}

然后将值复制给这个VO类,返回VO

java 复制代码
 @Override
    public QuestionDetailVO detail(Long questionId) {
        Question question = questionMapper.selectById(questionId);
        if (question == null) {
            throw new ServiceException(ResultCode.FAILED_NOT_EXISTS);
        }
        QuestionDetailVO questionDetailVO = new QuestionDetailVO();
        BeanUtil.copyProperties(question, questionDetailVO);
        return questionDetailVO;
    }

然后继续进行修改操作

java 复制代码
  //  /question/edit
    @PutMapping("/edit")
    public R<Void> edit(@RequestBody QuestionEditDTO questionEditDTO) {
        return toR(questionService.edit(questionEditDTO));
    }

通过前端的输入框获得数据,然后点击按键去进行调用后端函数,将参数传入赋值

java 复制代码
  @Override
    public int edit(QuestionEditDTO questionEditDTO) {
        Question oldQuestion = questionMapper.selectById(questionEditDTO.getQuestionId());
        if (oldQuestion == null) {
            throw new ServiceException(ResultCode.FAILED_NOT_EXISTS);
        }
        oldQuestion.setTitle(questionEditDTO.getTitle());
        oldQuestion.setDifficulty(questionEditDTO.getDifficulty());
        oldQuestion.setTimeLimit(questionEditDTO.getTimeLimit());
        oldQuestion.setSpaceLimit(questionEditDTO.getSpaceLimit());
        oldQuestion.setContent(questionEditDTO.getContent());
        oldQuestion.setQuestionCase(questionEditDTO.getQuestionCase());
        oldQuestion.setDefaultCode(questionEditDTO.getDefaultCode());
        oldQuestion.setMainFuc(questionEditDTO.getMainFuc());
        return questionMapper.updateById(oldQuestion);
    }

通过id去搜索搜索之前存入的数据,如果不存在抛出异常,

然后对之前的内容进行赋值,之后使用Mapper进行修改

删除

有了前面俩个的学习,我们接下来就会轻松许多,我们这里后端只做第三步

直接通过id去数据库进行删除操作

java 复制代码
    //  /question/delete
    @DeleteMapping("/delete")
    public R<Void> delete(Long questionId) {
        return toR(questionService.delete(questionId));
    }
java 复制代码
 @Override
    public int delete(Long questionId) {
        Question question = questionMapper.selectById(questionId);
        if (question == null) {
            throw new ServiceException(ResultCode.FAILED_NOT_EXISTS);
        }
        return questionMapper.deleteById(questionId);
    }
相关推荐
云知谷11 小时前
【C++基本功】C++适合做什么,哪些领域适合哪些领域不适合?
c语言·开发语言·c++·人工智能·团队开发
l1t12 小时前
DeepSeek辅助利用搬移底层xml实现快速编辑xlsx文件的python程序
xml·开发语言·python·xlsx
C_Liu_14 小时前
C++:list
开发语言·c++
my rainy days14 小时前
C++:友元
开发语言·c++·算法
小梁努力敲代码14 小时前
java数据结构--List的介绍
java·开发语言·数据结构
摸鱼的老谭14 小时前
构建Agent该选Python还是Java ?
java·python·agent
云知谷15 小时前
【HTML】网络数据是如何渲染成HTML网页页面显示的
开发语言·网络·计算机网络·html
lang2015092815 小时前
Spring Boot 官方文档精解:构建与依赖管理
java·spring boot·后端
夫唯不争,故无尤也15 小时前
Tomcat 启动后只显示 index.jsp,没有进入你的 Servlet 逻辑
java·servlet·tomcat
zz-zjx15 小时前
Tomcat核心组件全解析
java·tomcat