十次方微服务项目实战05--招聘问答模块微服务开发及代码自动生成

本文主要是介绍十次方微服务项目实战05--招聘问答模块微服务开发及代码自动生成,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、招聘微服务模块

1.1 原型

先来看一下页面原型,如图:
在这里插入图片描述
招聘微服务主要有两块:企业信息和招聘信息
两个大功能:推荐职位和最新职位

1.2 表结构分析

1.2.1 企业表

在这里插入图片描述

1.2.2 招聘信息表

在这里插入图片描述

1.3 代码生成

接下来使用开源代码生成器codeutil 来完成代码的生成
开源网址: https://gitee.com/chuanzhiliubei/codeutil

生成步骤:

  1. 使用代码生成器生成招聘微服务代码 tensquare_recruit
  2. 拷贝到当前工程,并在父工程引入
  3. 修改Application类名称为RecruitApplication
  4. 修改application.yml中的端口为9002urljdbc:mysql://127.0.0.1:3306/tensquare_recruit?characterEncoding=UTF8
  5. 使用Postman进行测试

1.4 热门企业列表

需求:查询企业表ishot字段为1的记录

1.4.1 EnterpriseDao新增方法定义
	/*** 根据热门状态获取企业列表* @param ishot* @return*/public List<Enterprise> findByIshot(String ishot); // where ishot = ?
1.4.2 EnterpriseService新增方法
	/*** 查询热门企业列表** @return*/public List<Enterprise> hotList() {return enterpriseDao.findByIshot("1");}
1.4.3 EnterpriseController新增方法
@RequestMapping(value = "/search/hotlist", method = RequestMethod.GET)
public Result hotList() {return Result.ok(enterpriseService.hotList());}
1.4.4 测试

访问如下网址进行测试:http://localhost:9002/enterprise/search/hotlist

1.5 推荐职位列表

需求:查询状态为2并以创建日期降序排序,查询前4条记录

1.5.1 RecruitDao新增方法定义
    /*** 根据职位状态查询前4条记录,并以创建日期降序排序** @param state* @return*/List<Recruit> findTop4ByStateOrderByCreatetimeDesc(String state);// where state = ? order by createtime desc	
1.5.2 RecruitService新增方法
public List<Recruit> findTop4ByStateOrderByCreatetimeDesc(String state) {return recruitDao.findTop4ByStateOrderByCreatetimeDesc(state);}
1.5.3 RecruitController新增方法
    /*** 查询推荐职位列表** @return*/@RequestMapping(value = "/search/recommend", method = RequestMethod.GET)public Result recommend() {return Result.ok(recruitService.findTop4ByStateOrderByCreatetimeDesc("2"));}
1.5.4 测试

访问如下网址进行测试:http://localhost:9002/enterprise/search/recommend

1.6 最新职位列表

需求:查询状态不为0并以创建日期降序排序,查询前12条记录

1.6.1 RecruitDao新增方法定义
  /*** 最新职位列表** @param state* @return*/List<Recruit> findByStateNotOrderByCreatetimeDesc(String state);// where state != ? order by createtime desc
1.6.2 RecruitService新增方法
   public List<Recruit> newList(String state) {return recruitDao.findByStateNotOrderByCreatetimeDesc(state);}
1.6.3 RecruitController新增方法
/*** 查询最新职位列表** @return*/@RequestMapping(value = "/search/newlist", method = RequestMethod.GET)public Result newList() {return Result.ok(recruitService.newList("0"));}
1.6.4 测试

访问如下网址进行测试:http://localhost:9002/enterprise/search/newslist

二、问答微服务模块

2.1 原型

先来看一下页面原型,如图:
在这里插入图片描述
招聘微服务主要有三个大功能:最新回答、热门回答和等待回答

2.2 表结构分析

2.2.1 问题表

在这里插入图片描述

2.2.2 回复表

在这里插入图片描述

2.2.3 问答标签中间表

在这里插入图片描述

2.3 代码生成

接下来使用开源代码生成器codeutil 来完成代码的生成
开源网址: https://gitee.com/chuanzhiliubei/codeutil

生成步骤:

  1. 使用代码生成器生成招聘微服务代码 tensquare_qa
  2. 拷贝到当前工程,并在父工程引入
  3. 修改Application类名称为QAApplication
  4. 修改application.yml中的端口为9003urljdbc:mysql://127.0.0.1:3306/tensquare_qa?characterEncoding=UTF8
  5. 使用Postman进行测试

2.4 最新回答列表

需求:最新回复的问题显示在上方, 按回复时间降序排序

2.4.1 创建中间表pl的实体类

新建PL.java如下:

@Entity
@Table(name = "tb_pl")
public class PL implements Serializable {@Idprivate String problemid;@Idprivate String lableid;public String getProblemid() {return problemid;}public void setProblemid(String problemid) {this.problemid = problemid;}public String getLableid() {return lableid;}public void setLableid(String lableid) {this.lableid = lableid;}
}
2.4.2 ProblemDao新增方法定义
/*** 根据标签ID查询最新问题列表* @param labelId* @param pageable* @return*/@Query(value = "select p from Problem p where id in(select problemid from PL where labelid = ?1) order by replytime desc")public Page<Problem> findNewListByLabelId(String labelId, Pageable pageable);
2.4.3 ProblemService新增方法
/*** 查询最新回答列表** @param labelId* @param page* @param size* @return*/public Page<Problem> findNewListByLabelId(String labelId, int page, int size) {PageRequest pageRequest = PageRequest.of(page - 1, size);return problemDao.findNewListByLabelId(labelId, pageRequest);}
2.4.4 ProblemController新增方法
	/*** 最新回答* @param labelId* @param page* @param size* @return*/@RequestMapping(value = "/newlist/{labelId}/{page}/{size}")public Result findNewListByLabelId(@PathVariable String labelId, @PathVariable int page, @PathVariable int size) {Page<Problem> pageList = problemService.findNewListByLabelId(labelId, page, size);PageResult pageResult = new PageResult<>(pageList.getTotalPages(), pageList.getContent());return Result.ok(pageResult);}
2.4.5 测试

访问如下网址进行测试:http://localhost:9003/problem/newlist/1/1/5

2.5 推荐职位列表

需求:按回复数降序排序

2.5.1 ProblemDao新增方法定义
	/*** 根据标签ID查询热门问题列表** @param labelId* @param pageable* @return*/@Query(value = "select p from Problem p where id in(select problemid from PL where labelid = ?1) order by reply desc")public Page<Problem> findHotListByLabelId(String labelId, Pageable pageable);
2.5.2 ProblemService新增方法
/*** 查询热门回答列表** @param labelId* @param page* @param size* @return*/public Page<Problem> findHotListByLabelId(String labelId, int page, int size) {PageRequest pageRequest = PageRequest.of(page - 1, size);return problemDao.findHotListByLabelId(labelId, pageRequest);}
2.5.3 ProblemController新增方法
	/*** 热门回答** @param labelId* @param page* @param size* @return*/@RequestMapping(value = "/hotlist/{labelId}/{page}/{size}")public Result findHotListByLabelId(@PathVariable String labelId, @PathVariable int page, @PathVariable int size) {Page<Problem> pageList = problemService.findNewListByLabelId(labelId, page, size);PageResult pageResult = new PageResult<>(pageList.getTotalPages(), pageList.getContent());return Result.ok(pageResult);}
2.5.4 测试

访问如下网址进行测试:http://localhost:9003/problem/hotlist/1/1/5

2.6 等待回答列表

需求:查询尚无人回答列表(reply=0)

2.6.1 ProblemDao新增方法定义
	/*** 根据标签ID查询等待回答问题列表** @param labelId* @param pageable* @return*/@Query(value = "select p from Problem p where id in(select problemid from PL where labelid = ?1) and reply =0 order by createtime desc")public Page<Problem> findWaitReplyListByLabelId(String labelId, Pageable pageable);
2.6.2 ProblemService新增方法
	/*** 查询等待回答列表** @param labelId* @param page* @param size* @return*/public Page<Problem> findWaitReplyListByLabelId(String labelId, int page, int size) {PageRequest pageRequest = PageRequest.of(page - 1, size);return problemDao.findWaitReplyListByLabelId(labelId, pageRequest);}
2.6.3 ProblemController新增方法
	/*** 等待回答** @param labelId* @param page* @param size* @return*/@RequestMapping(value = "/waitlist/{labelId}/{page}/{size}")public Result findWaitReplyListByLabelId(@PathVariable String labelId, @PathVariable int page, @PathVariable int size) {Page<Problem> pageList = problemService.findWaitReplyListByLabelId(labelId, page, size);PageResult pageResult = new PageResult<>(pageList.getTotalPages(), pageList.getContent());return Result.ok(pageResult);}
2.6.4 测试

访问如下网址进行测试:http://localhost:9003/problem/waitlist/1/1/5

三、小结

本文主要介绍了:

  • 招聘表结构分析&微服务模块开发
  • 问答表结构分析&微服务模块开发
  • 通过工具自动生成代码
  • HQL语句编写

这篇关于十次方微服务项目实战05--招聘问答模块微服务开发及代码自动生成的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/982417

相关文章

关于DNS域名解析服务

《关于DNS域名解析服务》:本文主要介绍关于DNS域名解析服务,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录DNS系统的作用及类型DNS使用的协议及端口号DNS系统的分布式数据结构DNS的分布式互联网解析库域名体系结构两种查询方式DNS服务器类型统计构建DNS域

SpringBoot+Docker+Graylog 如何让错误自动报警

《SpringBoot+Docker+Graylog如何让错误自动报警》SpringBoot默认使用SLF4J与Logback,支持多日志级别和配置方式,可输出到控制台、文件及远程服务器,集成ELK... 目录01 Spring Boot 默认日志框架解析02 Spring Boot 日志级别详解03 Sp

从原理到实战深入理解Java 断言assert

《从原理到实战深入理解Java断言assert》本文深入解析Java断言机制,涵盖语法、工作原理、启用方式及与异常的区别,推荐用于开发阶段的条件检查与状态验证,并强调生产环境应使用参数验证工具类替代... 目录深入理解 Java 断言(assert):从原理到实战引言:为什么需要断言?一、断言基础1.1 语

Python中re模块结合正则表达式的实际应用案例

《Python中re模块结合正则表达式的实际应用案例》Python中的re模块是用于处理正则表达式的强大工具,正则表达式是一种用来匹配字符串的模式,它可以在文本中搜索和匹配特定的字符串模式,这篇文章主... 目录前言re模块常用函数一、查看文本中是否包含 A 或 B 字符串二、替换多个关键词为统一格式三、提

Java MQTT实战应用

《JavaMQTT实战应用》本文详解MQTT协议,涵盖其发布/订阅机制、低功耗高效特性、三种服务质量等级(QoS0/1/2),以及客户端、代理、主题的核心概念,最后提供Linux部署教程、Sprin... 目录一、MQTT协议二、MQTT优点三、三种服务质量等级四、客户端、代理、主题1. 客户端(Clien

Java中调用数据库存储过程的示例代码

《Java中调用数据库存储过程的示例代码》本文介绍Java通过JDBC调用数据库存储过程的方法,涵盖参数类型、执行步骤及数据库差异,需注意异常处理与资源管理,以优化性能并实现复杂业务逻辑,感兴趣的朋友... 目录一、存储过程概述二、Java调用存储过程的基本javascript步骤三、Java调用存储过程示

Visual Studio 2022 编译C++20代码的图文步骤

《VisualStudio2022编译C++20代码的图文步骤》在VisualStudio中启用C++20import功能,需设置语言标准为ISOC++20,开启扫描源查找模块依赖及实验性标... 默认创建Visual Studio桌面控制台项目代码包含C++20的import方法。右键项目的属性:

Linux中SSH服务配置的全面指南

《Linux中SSH服务配置的全面指南》作为网络安全工程师,SSH(SecureShell)服务的安全配置是我们日常工作中不可忽视的重要环节,本文将从基础配置到高级安全加固,全面解析SSH服务的各项参... 目录概述基础配置详解端口与监听设置主机密钥配置认证机制强化禁用密码认证禁止root直接登录实现双因素

在Spring Boot中集成RabbitMQ的实战记录

《在SpringBoot中集成RabbitMQ的实战记录》本文介绍SpringBoot集成RabbitMQ的步骤,涵盖配置连接、消息发送与接收,并对比两种定义Exchange与队列的方式:手动声明(... 目录前言准备工作1. 安装 RabbitMQ2. 消息发送者(Producer)配置1. 创建 Spr

浏览器插件cursor实现自动注册、续杯的详细过程

《浏览器插件cursor实现自动注册、续杯的详细过程》Cursor简易注册助手脚本通过自动化邮箱填写和验证码获取流程,大大简化了Cursor的注册过程,它不仅提高了注册效率,还通过友好的用户界面和详细... 目录前言功能概述使用方法安装脚本使用流程邮箱输入页面验证码页面实战演示技术实现核心功能实现1. 随机