十次方微服务项目实战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

相关文章

Java编译生成多个.class文件的原理和作用

《Java编译生成多个.class文件的原理和作用》作为一名经验丰富的开发者,在Java项目中执行编译后,可能会发现一个.java源文件有时会产生多个.class文件,从技术实现层面详细剖析这一现象... 目录一、内部类机制与.class文件生成成员内部类(常规内部类)局部内部类(方法内部类)匿名内部类二、

使用Jackson进行JSON生成与解析的新手指南

《使用Jackson进行JSON生成与解析的新手指南》这篇文章主要为大家详细介绍了如何使用Jackson进行JSON生成与解析处理,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 核心依赖2. 基础用法2.1 对象转 jsON(序列化)2.2 JSON 转对象(反序列化)3.

springboot循环依赖问题案例代码及解决办法

《springboot循环依赖问题案例代码及解决办法》在SpringBoot中,如果两个或多个Bean之间存在循环依赖(即BeanA依赖BeanB,而BeanB又依赖BeanA),会导致Spring的... 目录1. 什么是循环依赖?2. 循环依赖的场景案例3. 解决循环依赖的常见方法方法 1:使用 @La

使用C#代码在PDF文档中添加、删除和替换图片

《使用C#代码在PDF文档中添加、删除和替换图片》在当今数字化文档处理场景中,动态操作PDF文档中的图像已成为企业级应用开发的核心需求之一,本文将介绍如何在.NET平台使用C#代码在PDF文档中添加、... 目录引言用C#添加图片到PDF文档用C#删除PDF文档中的图片用C#替换PDF文档中的图片引言在当

C#使用SQLite进行大数据量高效处理的代码示例

《C#使用SQLite进行大数据量高效处理的代码示例》在软件开发中,高效处理大数据量是一个常见且具有挑战性的任务,SQLite因其零配置、嵌入式、跨平台的特性,成为许多开发者的首选数据库,本文将深入探... 目录前言准备工作数据实体核心技术批量插入:从乌龟到猎豹的蜕变分页查询:加载百万数据异步处理:拒绝界面

用js控制视频播放进度基本示例代码

《用js控制视频播放进度基本示例代码》写前端的时候,很多的时候是需要支持要网页视频播放的功能,下面这篇文章主要给大家介绍了关于用js控制视频播放进度的相关资料,文中通过代码介绍的非常详细,需要的朋友可... 目录前言html部分:JavaScript部分:注意:总结前言在javascript中控制视频播放

Spring Boot + MyBatis Plus 高效开发实战从入门到进阶优化(推荐)

《SpringBoot+MyBatisPlus高效开发实战从入门到进阶优化(推荐)》本文将详细介绍SpringBoot+MyBatisPlus的完整开发流程,并深入剖析分页查询、批量操作、动... 目录Spring Boot + MyBATis Plus 高效开发实战:从入门到进阶优化1. MyBatis

MyBatis 动态 SQL 优化之标签的实战与技巧(常见用法)

《MyBatis动态SQL优化之标签的实战与技巧(常见用法)》本文通过详细的示例和实际应用场景,介绍了如何有效利用这些标签来优化MyBatis配置,提升开发效率,确保SQL的高效执行和安全性,感... 目录动态SQL详解一、动态SQL的核心概念1.1 什么是动态SQL?1.2 动态SQL的优点1.3 动态S

Python基于wxPython和FFmpeg开发一个视频标签工具

《Python基于wxPython和FFmpeg开发一个视频标签工具》在当今数字媒体时代,视频内容的管理和标记变得越来越重要,无论是研究人员需要对实验视频进行时间点标记,还是个人用户希望对家庭视频进行... 目录引言1. 应用概述2. 技术栈分析2.1 核心库和模块2.2 wxpython作为GUI选择的优

Pandas使用SQLite3实战

《Pandas使用SQLite3实战》本文主要介绍了Pandas使用SQLite3实战,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录1 环境准备2 从 SQLite3VlfrWQzgt 读取数据到 DataFrame基础用法:读