分页查询面试记录和面试详情

news2025/1/25 9:18:39

文章目录

    • 1.分页查询面试记录
        • 1.req和vo
          • 1.InterviewHistoryReq.java
          • 2.InterviewHistoryVO.java
        • 2.InterviewController.java
        • 3.service
          • 1.InterviewHistoryService.java
          • 2.InterviewHistoryServiceImpl.java
        • 4.测试
    • 2.查询面试详情
        • 1.InterviewQuestionHistoryVO.java
        • 2.InterviewController.java
        • 3.InterviewQuestionHistoryService.java
        • 4.InterviewQuestionHistoryServiceImpl.java
        • 5.测试

1.分页查询面试记录

1.req和vo
1.InterviewHistoryReq.java
package com.sunxiansheng.interview.server.entity.req;

import com.sunxiansheng.interview.server.entity.page.PageInfo;
import lombok.Data;
import lombok.experimental.Accessors;

import java.io.Serializable;

/**
 * 分页信息
 *
 * @author sun
 * @since 2024-07-21 16:03:41
 */
@Data
@Accessors(chain = true) // 支持链式调用
public class InterviewHistoryReq implements Serializable {

    private static final long serialVersionUID = 1L;

    /**
     * 分页信息
     */
    private PageInfo pageInfo;

}

2.InterviewHistoryVO.java
package com.sunxiansheng.interview.api.vo;

import lombok.Data;

import java.io.Serializable;

/**
 * 面试汇总记录表(InterviewHistory)实体类
 *
 * @author makejava
 * @since 2024-05-23 22:56:03
 */
@Data
public class InterviewHistoryVO implements Serializable {
    private static final long serialVersionUID = -69404155056273562L;
    /**
     * id
     */
    private Long id;
    /**
     * 平均分
     */
    private double avgScore;
    /**
     * 面试关键字
     */
    private String keyWords;
    /**
     * 面试评价
     */
    private String tip;
    /**
     * 创建时间
     */
    private Long createdTime;

}

2.InterviewController.java
    /**
     * 分页查询面试记录
     */
    @PostMapping(value = "/getHistory")
    public Result<PageResult<InterviewHistoryVO>> getHistory(@RequestBody InterviewHistoryReq req) {
        try {
            if (log.isInfoEnabled()) {
                log.info("分页查询面试记录入参{}", JSON.toJSONString(req));
            }
            Preconditions.checkArgument(!Objects.isNull(req), "参数不能为空!");
            PageResult<InterviewHistoryVO> result = interviewHistoryService.getHistory(req);
            if (log.isInfoEnabled()) {
                log.info("分页查询面试记录出参{}", JSON.toJSONString(result));
            }
            return Result.ok(result);
        } catch (IllegalArgumentException e) {
            log.error("参数异常!错误原因{}", e.getMessage(), e);
            return Result.fail(e.getMessage());
        } catch (Exception e) {
            log.error("分页查询面试记录异常!错误原因{}", e.getMessage(), e);
            return Result.fail("分页查询面试记录异常!");
        }
    }
3.service
1.InterviewHistoryService.java
    PageResult<InterviewHistoryVO> getHistory(InterviewHistoryReq req);
2.InterviewHistoryServiceImpl.java
    /**
     * 分页查询
     *
     * @param req
     * @return
     */
    @Override
    public PageResult<InterviewHistoryVO> getHistory(InterviewHistoryReq req) {
        // 构造查询条件
        InterviewHistoryPo interviewHistoryPo = new InterviewHistoryPo();
        interviewHistoryPo.setCreatedBy(LoginUtil.getLoginId());
        Integer pageNo = req.getPageInfo().getPageNo();
        Integer pageSize = req.getPageInfo().getPageSize();
        PageResult<InterviewHistoryPo> paginate = SunPageHelper.paginate(pageNo, pageSize,
                () -> this.interviewHistoryMapper.count(interviewHistoryPo),
                (offset, limit) -> this.interviewHistoryMapper.queryPage(interviewHistoryPo, offset, limit));
        List<InterviewHistoryPo> result = paginate.getResult();
        List<InterviewHistoryVO> collect = result.stream().map(
                res -> {
                    InterviewHistoryVO interviewHistoryVO = new InterviewHistoryVO();
                    interviewHistoryVO.setId(res.getId());
                    interviewHistoryVO.setAvgScore(res.getAvgScore());
                    interviewHistoryVO.setKeyWords(res.getKeyWords());
                    interviewHistoryVO.setTip(res.getTip());
                    interviewHistoryVO.setCreatedTime(res.getCreatedTime().getTime());
                    return interviewHistoryVO;
                }
        ).collect(Collectors.toList());
        PageResult<InterviewHistoryVO> build = new PageResult.Builder<InterviewHistoryVO>()
                .pageNo(pageNo)
                .pageSize(pageSize)
                .total(paginate.getTotal())
                .result(collect)
                .build();
        return build;
    }
4.测试

CleanShot 2024-07-24 at 15.49.31@2x

2.查询面试详情

1.InterviewQuestionHistoryVO.java
package com.sunxiansheng.interview.api.vo;

import lombok.Data;

import java.io.Serializable;

/**
 * 面试题目记录表(InterviewQuestionHistory)实体类
 *
 * @author makejava
 * @since 2024-05-23 22:56:31
 */
@Data
public class InterviewQuestionHistoryVO implements Serializable {
    private static final long serialVersionUID = -60560874889446691L;

    /**
     * 均分
     */
    private Double score;
    /**
     * 面试关键字
     */
    private String keyWords;
    /**
     * 问题
     */
    private String question;
    /**
     * 答案
     */
    private String answer;
    /**
     * 用户答案
     */
    private String userAnswer;


}


2.InterviewController.java
    /**
     * 查询详情
     */
    @GetMapping(value = "/detail")
    public Result<List<InterviewQuestionHistoryVO>> detail(Long id) {
        try {
            if (log.isInfoEnabled()) {
                log.info("查询详情入参{}", id);
            }
            Preconditions.checkArgument(!Objects.isNull(id), "参数不能为空!");
            List<InterviewQuestionHistoryVO> result = interviewQuestionHistoryService.detail(id);
            if (log.isInfoEnabled()) {
                log.info("查询详情出参{}", JSON.toJSONString(result));
            }
            return Result.ok(result);
        } catch (IllegalArgumentException e) {
            log.error("参数异常!错误原因{}", e.getMessage(), e);
            return Result.fail(e.getMessage());
        } catch (Exception e) {
            log.error("查询详情异常!错误原因{}", e.getMessage(), e);
            return Result.fail("查询详情异常!");
        }
    }
3.InterviewQuestionHistoryService.java
    /**
     * 详情
     * @param id
     * @return
     */
    List<InterviewQuestionHistoryVO> detail(Long id);
4.InterviewQuestionHistoryServiceImpl.java
    /**
     * 详情
     * @param id
     * @return
     */
    @Override
    public List<InterviewQuestionHistoryVO> detail(Long id) {
        InterviewQuestionHistoryPo interviewQuestionHistoryPo = new InterviewQuestionHistoryPo();
        interviewQuestionHistoryPo.setInterviewId(id);
        interviewQuestionHistoryPo.setCreatedBy(LoginUtil.getLoginId());
        List<InterviewQuestionHistoryPo> interviewQuestionHistoryPoList = this.interviewQuestionHistoryMapper.queryAllByLimit(interviewQuestionHistoryPo);
        List<InterviewQuestionHistoryVO> collect = interviewQuestionHistoryPoList.stream().map(
                interviewQuestionHistoryPo1 -> {
                    InterviewQuestionHistoryVO interviewQuestionHistoryVO = new InterviewQuestionHistoryVO();
                    interviewQuestionHistoryVO.setScore(interviewQuestionHistoryPo1.getScore());
                    interviewQuestionHistoryVO.setKeyWords(interviewQuestionHistoryPo1.getKeyWords());
                    interviewQuestionHistoryVO.setQuestion(interviewQuestionHistoryPo1.getQuestion());
                    interviewQuestionHistoryVO.setAnswer(interviewQuestionHistoryPo1.getAnswer());
                    interviewQuestionHistoryVO.setUserAnswer(interviewQuestionHistoryPo1.getUserAnswer());
                    return interviewQuestionHistoryVO;
                }
        ).collect(Collectors.toList());
        return collect;
    }
5.测试

CleanShot 2024-07-24 at 16.09.04@2x

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2069645.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

适合开发人员的网页爬虫工具DrissionPage

DrissionPage是一个基于Python的网页自动化工具,它集成了Selenium和Requests的功能,既能够控制浏览器进行用户界面的模拟操作,也能够直接收发数据包进行数据的获取和处理。 开源地址:DrissionPage: 基于python的网页自动化工具。既能控制浏览器,也能收发数据包。可兼顾浏…

CLion调试ROS(包括launch启动的ROS)

打开一个终端&#xff0c;切换到工作空间目录(形如&#xff1a;&#xff5e;/catkin_ws)。 在终端输入&#xff0c;source ./devel/setup.bash 启动Clion&#xff0c;一定要在输入上述命令的窗口启动Clion&#xff0c;否则会存在一些问题。 打开工程&#xff0c;这里也是一个…

【Java】——Java实现数组元素反转的两种方法

在编程中&#xff0c;我们经常会遇到需要对数组元素进行反转的需求。例如&#xff0c;给定一个整数数组arr {1, 2, 3, 4, 5}&#xff0c;我们需要将其反转为{5, 4, 3, 2, 1}。下面我们将介绍两种实现数组元素反转的方法。 方法一&#xff1a;遍历数组一半的长度进行元素互换 …

Spring注解:优雅管理依赖的艺术

在Java企业级开发的广阔天地中&#xff0c;Spring框架以其强大的依赖注入&#xff08;DI&#xff09;和面向切面编程&#xff08;AOP&#xff09;能力&#xff0c;成为了众多开发者的首选。而Spring注解&#xff0c;作为这一框架的核心特性之一&#xff0c;更是将依赖管理提升到…

如何通过数字化资产管理提升企业运营效率

在当今快速发展的商业环境中&#xff0c;企业的资产管理正逐步向数字化迈进。数字化资产管理系统不仅帮助企业提高资产利用率&#xff0c;还能降低管理成本&#xff0c;提升整体运营效率。常达智能物联为各行业企业提供了领先的数字化资产管理解决方案&#xff0c;帮助企业实现…

AI入门指南(四):分类问题、回归问题、监督、半监督、无监督学习是什么?

文章目录 一、前言二、分类问题、回归问题是什么&#xff1f;分类问题概念常见算法分类问题的实际应用&#xff1a;银行贷款审批案例 回归问题概念常见算法回归问题实际应用&#xff1a;线性回归模型预测房价 小结 三、监督、半监督、非监督学习是什么&#xff1f;监督学习非监…

C语言基础(十五)

指针的使用&#xff1a; 测试代码1&#xff1a; #include <stdio.h> // 标准的 main 函数声明&#xff0c;包括可选的 envp 参数 int main(int argc, char *argv[], char *envp[]) { // argc 命令行参数的数量&#xff08;包括程序名&#xff09; // argv 指向字…

github源码指引:一个自制代码生成器(嵌入式脚本语言)

初级代码游戏的专栏介绍与文章目录-CSDN博客 我的github&#xff1a;codetoys&#xff0c;所有代码都将会位于ctfc库中。已经放入库中我会指出在库中的位置。 这些代码大部分以Linux为目标但部分代码是纯C的&#xff0c;可以在任何平台上使用。 源码目录&#xff1a;CodeTemp…

Global Illumination_Reflective Shadow Maps Deep Optimizations

之前写过一篇Global Illumination_Reflective Shadow Maps&#xff08;RSM&#xff09;、Virtual Point Light&#xff08;VPL&#xff09;&#xff0c;近期重拾传统GI技术的实际工程场景中的应用&#xff0c;于是从效率方面对RSM、LPV、VCT技术进行效率优化&#xff0c;后续逐…

HTML 全解析:从基础到实战

一、简介 HTML&#xff08;HyperText Markup Language&#xff09;即超文本标记语言&#xff0c;是用于创建网页的标准标记语言。它通过各种标签来定义网页的结构和内容&#xff0c;使得浏览器能够正确地显示网页。HTML 文档由 HTML 元素组成&#xff0c;这些元素通过标签来表…

桌面整理大师 - Mac(苹果电脑)桌面整理工具软件

桌面整理大师 与 DeskWidgets 来自同一开发者&#xff0c;是一款专为 macOS 打造的桌面分区整理工具。 与 DeskWidgets 的文件分区组件相比&#xff0c;桌面整理大师拥有更加强大的功能&#xff0c;支持调整分区的大小和样式、可快速查看非桌面目录的文件…… 桌面整理大师的宗…

【Docker】Docker学习02 | docker-cli的基本命令

本文首发于 ❄️慕雪的寒舍 简单了解一下docker client的常用命令&#xff0c;更多命令可以查看完整命令列表。不同命令之间的关系&#xff0c;可以查看下图。 如果你看不到图片&#xff0c;不用担心&#xff0c;后面对每个命令进行介绍的时候&#xff0c;会提到它们的作用的。…

内存之RAM、SRAM、DRAM、ROM、FLASH、SDRAM、DDR*(一篇文章就懂)

内存之RAM、SRAM、DRAM、ROM、FLASH、SDRAM、DDR* 内存 内存&#xff08;Memory&#xff09;指的是内存存储器&#xff0c;又称为主存&#xff0c;是CPU用来直接寻址和存储的空间&#xff0c;它相当于一座桥梁&#xff0c;用以负责诸如硬盘、主板、显卡等硬件上的数据与处理器…

高性价比开放式运动耳机有哪些?五大高性价比开放式耳机分享

作为一名数码爱好者&#xff0c;从93年入坑耳机、音响等各类电子产品以来&#xff0c;一直在测试不同品牌、不同价位的产品。现在开放式耳机比较热门&#xff0c;我自然也是不能错过的&#xff0c;开放式耳机拥有很多优点&#xff0c;很多采用人体工学设计&#xff0c;能够更加…

UE5打包iOS运行查看Crash日志

1、查看Crash 1、通过xCode打开设备 2、选择APP打开最近的日志 3、选择崩溃时间点对应的日志 4、选择对应的工程打开 5、就能看到对应的Crash日志 2、为了防止Crash写代码需要注意 1、UObject在RemoveFromRoot之前先判断是否Root if (SelectedImage && Selecte…

fl studio mobile2024最新官方版V4.6.8安卓版+iOS苹果版

fl studio mobile&#xff0c;一款非常好用的音乐制作软件。该软件具有丰富多样的音乐类型让大家选择&#xff0c;内置多个好用的编辑工具、渲染工具、特效工具等可以使用。用户可以自由使用软件中的任何道具&#xff0c;直接在手机上编曲&#xff0c;进行音乐创作&#xff0c;…

买超声波清洗机什么牌子好?好用的超声波清洗机推荐

尽管超声波清洗机对不少人而言较为新鲜&#xff0c;尤其是对非眼镜佩戴者&#xff0c;但它其实并不陌生&#xff0c;常现身于眼镜店作为专业清洁工具。有人或许认为&#xff0c;拂去眼镜尘埃仅需一擦即可&#xff0c;实际上&#xff0c;长时间佩戴后&#xff0c;镜片与框架累积…

【日常总结】阿里云:windows server 过一段时间登录不进去,或提示:出现身份验证错误。 无法连接到本地安全机构

场景 阿里云 : ESC系统&#xff1a;windows server 2022 问题 无法登录&#xff0c;或者登录浸提提示密码已过期 原因 密码设置了过期时间 解决方案 修改密码策略&#xff1a;密码设置永不过期 打开“本地安全策略”编辑器&#xff1a;运行 secpol.msc。 导航至“账户…

leetcode 2461.长度为k子数组的最大和

目录 题目描述 示例1&#xff1a; 示例2&#xff1a; 提示&#xff1a; 解题思路 滑动窗口法 概念 应用场景及特点&#xff1a; 思路 流程展示 代码 复杂度分析 题目描述 给你一个整数数组nums和一个整数k。请你从nums中满足下述条件的全部子数组中找出最大子数组…

开放式耳机别人能听到吗?不堵耳、不入耳的设计才舒服

开放式耳机的设计允许空气自由流通&#xff0c;这通常意味着它们在播放音乐时会有声音泄露到外部环境。因此&#xff0c;与封闭或半封闭的入耳式耳机相比&#xff0c;开放式耳机在一定程度上是可以让周围的人听到你正在播放的音乐的。声音泄露的程度取决于多种因素&#xff0c;…