RuoYi-Vue 使用开发 人员管理-查询功能

说明:这里仅仅开发列表显示 与 查询功能,剩下的添加、修改等可能会遇到报错,后面有机会,会单独写一篇文章教学处理

1.了解开发需求

作为示例的二级开发,这里的人员管理,管理的是 部门信息,员工信息

部门管理:

  • 部门管理
  • 员工管理

2. 后台页面设计

后台菜单栏设计:

一级菜单:人员管理

        二级菜单:部门管理、员工管理

后台页面设计:

        1. 部门管理中:

以树状的方式呈现,通过点击当前部门会显示自己的子部门信息(如果存在则显示)

部门信息以树状的方式显示

        2. 员工管理:

以列表的形式显示所有的员工信息

3. 数据库设计

(注意:这里的createTime应该写成create_time、以及updateTime也应该写成update_time,才比较规范些,这部分的代码使用 ai 进行生成,刚开始没注意检查,不过,接下我还是会按照生成的代码进行讲解!)

sql 建表语句:

CREATE TABLE tb_employee (id INT AUTO_INCREMENT PRIMARY KEY,dept_id INT NOT NULL,employee_name VARCHAR(100) NOT NULL,employee_avatar VARCHAR(255), -- 存储头像图片的URL或文件路径employee_gender INT NOT NULL DEFAULT 0, -- 0: 未知, 1: 男性, 2: 女性employee_age INT,employee_phone VARCHAR(20),employee_info TEXT,createTime DATETIME DEFAULT CURRENT_TIMESTAMP,updateTime DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP
) ENGINE=InnoDB DEFAULT CHARSET=utf8;CREATE TABLE tb_dept (id INT AUTO_INCREMENT PRIMARY KEY,dept_name VARCHAR(100) NOT NULL,dept_parent_id INT, -- 如果是顶级部门,则为NULLdept_info TEXT,createTime DATETIME DEFAULT CURRENT_TIMESTAMP,updateTime DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP
);

4. 员工管理 - 开发-查询列表

(1)字典修改

因为所创建的数据库表的tb_employee的字段employee_gender的特殊性

而若依中原来有用户性别表sys_user_sex

 我们只需要根据我们的员工表的employee_gender

修改对应的字典键值即可:

(2)首先导入tb_dept和tb_employee表进代码生成器中

生成代码后将其使用后显示的界面(我之前有写过如何使用生成的代码):

(3)员工管理开发

因为员工管理相对比较好开发,所以我先从简单的开始进行开发,首先观察直接生成的表格

我们希望修改的效果:

  • 年龄查询:可以选择范围,而不是具体的某个值
  • 部门号显示:修改为具体的部门名
  • 去掉通过手机号查询方式

我们想去掉手机号的查询方式,只需删除手机号查询的部分代码,以及相关表单的属性即可

实现效果: 

将年龄部分的代码,修改为范围查询的代码即可


记得修改查询列表中的参数

可以删除多余的查询条件,这样看起来更加简洁些

前端页面展示:(但是还是无法进行搜索,这是因为还没有修改搜索对应的java代码) 

后端代码修改

首先在Employee实体中添加两个额外的查询字段名,以及对应的getter和setter方法

注意:如果是使用Mybatis-plus记得使用 @TableField(exist = false)注解 标明这两个字段不存在数据库表

然后在mapper.xml文件中找到对应表格列表的方法名id,修改判断条件为我们页面的查询

这样是成功进行搜索了,但是重置对年龄的范围查询没有反应

找到重置查询按钮的方法,添加这两个字段的重置即可

现在开始将部门号修改为显示为部门名

前端修改:

将显示的deptId字段修改为deptName字段

后端修改:

(建议大家最好重新创建一个新的EmployeeVo),为了方便演示我直接修改Employee的实体类

我在实体类中添加了deptName这个属性,并加上了getter和setter方法,这样方便我待会使用

通过观察代码,修改查询语句与显示的数据属性(这里需要会一点编程能力哦!)

这里你猜为什么还是保留deptId字段没有删除呢?因为我们后面可以还会使用到该deptId添加时,进行部门字典的判断,以及想通过该deptId查看该部门信息等改造,所以最好还是保留id相关的字段信息比较好哦!方便以后的扩展

 

实现效果:

5. 部门管理 - 开发

通过代码生成器创建导入后显示的界面:

(1)了解需要改造的地方

查询部分:我们需要将上级部门号的查询删除,新增通过创建时间进行查询

列表部分:我们希望添加创建时间和更新时间的列表,同时将上级部门号改造为上级部门名

(2)添加创建时间搜索框

将上级部门号改为上级部门名的方式和上面讲解的员工管理的部门号改造为部门名显示都差不多,所以这部分就当做给大家的练习题咯,接下来我将讲解,如何通过创建时间进行搜索:

前端部分:

需要创建params传递daterangeCreateTime的参数

 添加搜索框,我这里选择的是年月日的搜索框

 在查询时,将当前的daterangeCreateTime赋值给params

重置效果实现

 

后端代码:

注意观察实体类,在基础实体类,已经有params字段,所以不需要额外去添加

 最后只需要在DeptMapper.xml中修改下面的内容:

为了显示上级部门名:

查询语句的修改

以及对创建时间的范围的搜索

以上就是RuoYi-Vue的简单运用啦!

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Tomcat 11 下载/安装 与基本使用

为什么要使用Tomcat? 使用Apache Tomcat的原因有很多,以下是一些主要的优点和特点: 1. 开源与免费 Tomcat是一个完全开源的项目,任何人都可以免费使用。它由Apache软件基金会维护,拥有一个活跃的社区,这…

Django入门教程——用户管理实现

第六章 用户管理实现 教学目的 复习数据的增删改查的实现。了解数据MD5加密算法以及实现模型表单中,自定义控件的使用中间件的原理和使用 需求分析 系统问题 员工档案涉及到员工的秘密,不能让任何人都可以看到,主要是人事部门进行数据的…

[ 问题解决篇 ] 解决远程桌面安全登录框的问题

🍬 博主介绍 👨‍🎓 博主介绍:大家好,我是 _PowerShell ,很高兴认识大家~ ✨主攻领域:【渗透领域】【数据通信】 【通讯安全】 【web安全】【面试分析】 🎉点赞➕评论➕收藏 养成习…

微信小程序时间弹窗——年月日时分

需求 1、默认当前时间2、选择时间弹窗限制最大值、最小值3、每次弹起更新最大值为当前时间&#xff0c;默认值为上次选中时间4、 minDate: new Date(2023, 10, 1).getTime(),也可以传入时间字符串new Date(2023-10-1 12:22).getTime() html <view class"flex bb ptb…

【Spring框架】Spring框架的开发方式

目录 Spring框架开发方式前言具体案例导入依赖创建数据库表结构创建实体类编写持久层接口和实现类编写业务层接口和实现类配置文件的编写 IoC注解开发注解开发入门&#xff08;半注解&#xff09;IoC常用注解Spring纯注解方式开发 Spring整合JUnit测试 Spring框架开发方式 前言…

江协科技STM32学习- P24 DMA数据转运DMA+AD多通道

&#x1f680;write in front&#x1f680; &#x1f50e;大家好&#xff0c;我是黄桃罐头&#xff0c;希望你看完之后&#xff0c;能对你有所帮助&#xff0c;不足请指正&#xff01;共同学习交流 &#x1f381;欢迎各位→点赞&#x1f44d; 收藏⭐️ 留言&#x1f4dd;​…

【刷题11】CTFHub技能树sql注入系列

整数型注入 看到源码了&#xff0c;直接sql一套秒了 字符型注入 SQL 报错注入 构造payload 1 and (select extractvalue(1,concat(’~’,(select database())))) 后续步骤跟sql基本步骤一样 SQL 布尔注入 人工测试太麻烦&#xff0c;这里直接使用sqlmap,知道这有sql注入漏洞&am…

面试经典 150 题.P26. 删除有序数组中的重复项(003)

本题来自&#xff1a;力扣-面试经典 150 题 面试经典 150 题 - 学习计划 - 力扣&#xff08;LeetCode&#xff09;全球极客挚爱的技术成长平台https://leetcode.cn/studyplan/top-interview-150/ 题解&#xff1a; class Solution {public int removeDuplicates(int[] nums) …

docker中使用ros2humble的rviz2不显示问题

这里写目录标题 docker中使用ros2humble的rviz2不显示问题删除 Docker 镜像和容器删除 Docker 容器Linux服务器下查看系统CPU个数、核心数、(make编译最大的)线程数总结&#xff1a; RVIZ2 不能显示数据集 docker中使用ros2humble的rviz2不显示问题 问题描述&#xff1a; roo…

ELK + Filebeat + Spring Boot:日志分析入门与实践(二)

目录 一、环境 1.1 ELKF环境 1.2 版本 1.3 流程 二、Filebeat安装 2.1 安装 2.2 新增配置采集日志 三、logstash 配置 3.1 配置输出日志到es 3.2 Grok 日志格式解析 3.2 启动 logstash ​3.3 启动项目查看索引 一、环境 1.1 ELKF环境 springboot项目&#xff1a;w…

基于SSM土家风景文化管理系统的设计

管理员账户功能包括&#xff1a;系统首页&#xff0c;个人中心&#xff0c;用户管理&#xff0c;景点分类管理&#xff0c;热门景点管理&#xff0c;门票订单管理&#xff0c;旅游线路管理&#xff0c;系统管理 前提账号功能包括&#xff1a;系统首页&#xff0c;个人中心&…

Linux特种文件系统--tmpfs文件系统

tmpfs类似于RamDisk&#xff08;只能使用物理内存&#xff09;&#xff0c;使用虚拟内存&#xff08;简称VM&#xff09;子系统的页面存储文件。tmpfs完全依赖VM&#xff0c;遵循子系统的整体调度策略。说白了tmpfs跟普通进程差不多&#xff0c;使用的都是某种形式的虚拟内存&a…

不同概率分布的更新过程——Python实现(均匀分布、卡方分布、指数分布等作为概率分布的更新过程)

更新过程(renewal process)是描述元件或设备更新现象的一类随机过程。以下是对更新过程的详细介绍: 一、定义与特点 定义:设对某元件的工作进行观测,假定元件的使用寿命是一随机变量,当元件发生故障时就进行修理或换上新的同类元件,而且元件的更新是即时的(修理或更换…

GIT分布式版本控制系统基础操作

问题大纲 1、什么分布式版本控制系统 2、简述Git的使用分为哪几个步骤 3、克隆和拉取的区别是什么&#xff1f; 4、git相关的所有指令 一、分布式版本控制系统 分布式版本控制系统是一种版本控制系统&#xff0c;它允许每个用户都拥有完整的项目历史记录和版本控制信息。与…

ArcGIS必会的选择要素方法(AND、OR、R、IN等)位置选择等

今天来看看ArcGIS中的几个选择的重要使用方法 1、常规选择、 2、模糊查询、 3、组合复合条件查询&#xff08;AND、OR、IN&#xff09;&#xff0c; 4、空值NULL查询 5、位置选择 推荐学习&#xff1a; 以梦为马&#xff0c;超过万名学员学习ArcGIS入门到实战的应用课程…

Spring Bean创建流程

Spring Bean 创建流程图 大家总是会错误的理解Bean的“实例化”和“初始化”过程&#xff0c;总会以为初始化就是对象执行构造函数生成对象实例的过程&#xff0c;其实不然&#xff0c;在初始化阶段实际对象已经实例化出来了&#xff0c;初始化阶段进行的是依赖的注入和执行一…

rtp协议:rtcp包格式和传输间隔

RTP Control Protocol -- RTCP-rtp控制协议 实时传输控制协议&#xff08;RTCP&#xff09;基于对会话中的所有参与者定期传输控制包&#xff0c;使用与数据包相同的分发机制。底层协议必须提供数据包和控制包的多路复用&#xff0c;例如使用UDP时使用不同的端口号。RTCP执行四…

2024年医疗人工智能研究报告-生成式AI爆发,医疗人工智能走到新的十字路口(附下载)

前言 2024的医疗AI&#xff0c;既是坎坷&#xff0c;又是新生。 快速发展的大语言模型&#xff0c;携着生成式AI掠过医疗领域。过往的互联网医疗、医学影像、新药研发……一个一个场景经由新一代AI重塑&#xff0c;焕发出前所未有的价值。 不过&#xff0c;发现价值并不意味着…

网络请求自定义header导致跨域问题

我记得我的项目之前已经解决了跨域问题。 后来在功能开发着&#xff0c;需要添加一个自定义的header&#xff0c;发现又出现跨域报错。 于是又开始一通摸索折腾。 我的项目前面端是用axios网络请求&#xff0c;通过拦截器添加header&#xff0c;代码如下&#xff1a; //添加请…

macOS 15 Sequoia dmg格式转用于虚拟机的iso格式教程

想要把dmg格式转成iso格式&#xff0c;然后能在虚拟机上用&#xff0c;最起码新版的macOS镜像是不能用UltraISO&#xff0c;dmg2iso这种软件了&#xff0c;你直接转放到VMware里绝对读不出来&#xff0c;办法就是&#xff0c;在Mac系统中转换为cdr&#xff0c;然后再转成iso&am…