当前位置: 首页 > article >正文

Ruoyi-Vue3实战:10分钟搞定学生管理系统CRUD(附完整SQL)

Ruoyi-Vue3学生管理系统实战从零到部署的完整指南在当今快速迭代的开发环境中选择高效的技术栈至关重要。Ruoyi-Vue3作为基于Spring Boot和Vue3的企业级开发框架以其模块化设计和丰富的功能组件成为快速构建管理系统的首选方案。本文将带您完整实现一个学生信息管理系统涵盖数据库设计、前后端代码生成、联调测试等全流程特别适合需要快速交付教学演示或毕业设计的开发者。1. 环境准备与项目初始化在开始之前确保您的开发环境满足以下基础要求JDK 1.8或更高版本Node.js 14.x以上MySQL 5.7Maven 3.6Ruoyi-Vue3框架的安装可以通过以下步骤完成# 克隆项目仓库 git clone https://gitee.com/y_project/RuoYi-Vue.git # 进入项目目录 cd RuoYi-Vue # 安装前端依赖 npm install # 启动前端开发服务器 npm run dev后端项目需要使用Maven进行依赖管理在IntelliJ IDEA或Eclipse中导入项目后等待Maven自动下载所有依赖。首次启动前需要修改ruoyi-admin模块下的application.yml文件配置正确的数据库连接信息# 数据源配置 spring: datasource: driver-class-name: com.mysql.cj.jdbc.Driver url: jdbc:mysql://localhost:3306/ry-vue?useUnicodetruecharacterEncodingutf8zeroDateTimeBehaviorconvertToNulluseSSLtrueserverTimezoneGMT%2B8 username: root password: your_password2. 数据库设计与表创建学生管理系统的核心是合理的数据结构设计。我们建议采用以下字段设计tb_student表字段名类型允许空默认值描述idint否无主键ID自增namevarchar(255)否无学生姓名ageint是NULL学生年龄genderint是NULL性别(0男1女2其他)student_novarchar(50)是NULL学号class_idint是NULL班级IDphonevarchar(20)是NULL联系电话addressvarchar(500)是NULL家庭住址statuschar(1)是1状态(0停用1正常)del_flagchar(1)是0删除标志(0存在1删除)create_timedatetime是CURRENT_TIMESTAMP创建时间update_timedatetime是CURRENT_TIMESTAMP更新时间在Navicat中执行建表SQL的便捷方法连接MySQL数据库选择ry-vue数据库点击顶部菜单查询→新建查询粘贴以下SQL语句并执行CREATE TABLE tb_student ( id int NOT NULL AUTO_INCREMENT COMMENT 学生ID, name varchar(255) NOT NULL COMMENT 学生姓名, age int DEFAULT NULL COMMENT 年龄, gender int DEFAULT 0 COMMENT 性别(0男1女2其他), student_no varchar(50) DEFAULT NULL COMMENT 学号, class_id int DEFAULT NULL COMMENT 班级ID, phone varchar(20) DEFAULT NULL COMMENT 联系电话, address varchar(500) DEFAULT NULL COMMENT 家庭住址, status char(1) DEFAULT 1 COMMENT 状态(0停用1正常), del_flag char(1) DEFAULT 0 COMMENT 删除标志(0存在1删除), create_time datetime DEFAULT CURRENT_TIMESTAMP COMMENT 创建时间, update_time datetime DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT 更新时间, PRIMARY KEY (id), UNIQUE KEY idx_student_no (student_no) ) ENGINEInnoDB DEFAULT CHARSETutf8mb4 COLLATEutf8mb4_0900_ai_ci COMMENT学生信息表;提示在设计表结构时建议为可能频繁查询的字段如学号添加索引以提高查询性能。同时合理设置字段的默认值和约束条件可以减少业务逻辑中的空值判断。3. 代码生成与模块配置Ruoyi-Vue3的代码生成器能极大提升开发效率。按照以下步骤生成学生管理模块的基础代码创建系统菜单登录系统后台进入系统管理→菜单管理添加一级菜单学生管理设置路由路径为/student记住菜单ID后续代码生成会用到导入数据表并生成代码进入系统工具→代码生成点击导入按钮选择刚才创建的tb_student表在生成配置页面关键设置如下生成模板选择Vue3模板上级菜单选择刚创建的学生管理菜单模块名称填写student包路径com.ruoyi.student点击提交生成代码压缩包后端模块集成在项目根目录下创建ruoyi-student模块解压生成的代码将main目录内容复制到新模块中修改根目录和ruoyi-admin模块的pom.xml添加对新模块的依赖!-- 在ruoyi-admin的pom.xml中添加 -- dependency groupIdcom.ruoyi/groupId artifactIdruoyi-student/artifactId version${ruoyi.version}/version /dependency前端代码集成将生成的Vue组件文件复制到src/views/student目录路由配置通常会自动生成检查src/router/index.js确认路由已添加如果使用API自动导入确保src/api/student.js文件已正确创建注意代码生成器生成的SQL文件需要执行这些SQL通常包含必要的菜单权限配置。在开发环境中可以直接在Navicat中执行这些SQL文件。4. 功能扩展与自定义开发基础CRUD功能生成后通常需要根据实际需求进行定制开发。以下是几个常见的扩展场景4.1 添加复杂查询功能在学生列表页面默认生成的查询条件可能比较简单。我们可以扩展查询表单添加按班级、状态等多条件查询template el-form :modelqueryParams refqueryForm :inlinetrue el-form-item label学生姓名 propname el-input v-modelqueryParams.name placeholder请输入学生姓名 clearable / /el-form-item el-form-item label学号 propstudentNo el-input v-modelqueryParams.studentNo placeholder请输入学号 clearable / /el-form-item el-form-item label班级 propclassId el-select v-modelqueryParams.classId placeholder请选择班级 clearable el-option v-foritem in classOptions :keyitem.id :labelitem.name :valueitem.id / /el-select /el-form-item el-form-item label状态 propstatus el-select v-modelqueryParams.status placeholder请选择状态 clearable el-option label正常 value1 / el-option label停用 value0 / /el-select /el-form-item el-form-item el-button typeprimary iconel-icon-search clickhandleQuery搜索/el-button el-button iconel-icon-refresh clickresetQuery重置/el-button /el-form-item /el-form /template后端Controller需要相应调整查询接口GetMapping(/list) public TableDataInfo list(Student student) { startPage(); ListStudent list studentService.selectStudentList(student); return getDataTable(list); }4.2 添加数据导入导出功能Ruoyi框架内置了Excel导入导出功能可以轻松为学生管理系统添加这些特性在Student实体类中添加Excel注解Excel(name 学生姓名) private String name; Excel(name 年龄) private Integer age; Excel(name 性别, readConverterExp 0男,1女,2其他) private Integer gender; Excel(name 学号) private String studentNo;在Controller中添加导出方法PostMapping(/export) public void export(HttpServletResponse response, Student student) { ListStudent list studentService.selectStudentList(student); ExcelUtilStudent util new ExcelUtil(Student.class); util.exportExcel(response, list, 学生数据); }前端添加导出按钮并调用接口el-button typewarning plain iconel-icon-download clickhandleExport 导出/el-button // 方法实现 handleExport() { this.download(/student/export, { ...this.queryParams }, 学生数据_${new Date().getTime()}.xlsx) }4.3 添加数据统计图表利用ECharts为学生管理系统添加数据可视化安装ECharts依赖npm install echarts --save创建统计组件template div classchart-container div refgenderChart stylewidth: 100%; height: 400px;/div /div /template script import * as echarts from echarts; export default { data() { return { genderChart: null }; }, mounted() { this.initChart(); this.loadData(); }, methods: { initChart() { this.genderChart echarts.init(this.$refs.genderChart); this.genderChart.setOption({ title: { text: 学生性别分布, left: center }, tooltip: { trigger: item }, legend: { orient: vertical, left: left }, series: [ { name: 性别分布, type: pie, radius: 50%, data: [], emphasis: { itemStyle: { shadowBlur: 10, shadowOffsetX: 0, shadowColor: rgba(0, 0, 0, 0.5) } } } ] }); }, async loadData() { const res await this.$axios.get(/student/statistics/gender); this.genderChart.setOption({ series: [{ data: [ { value: res.data.male, name: 男生 }, { value: res.data.female, name: 女生 }, { value: res.data.other, name: 其他 } ] }] }); } } }; /script5. 部署与性能优化完成开发后项目需要部署到生产环境。Ruoyi-Vue3项目的前后端可以分开部署也可以一起部署。5.1 前端构建与部署前端项目构建命令# 生产环境构建 npm run build:prod构建完成后dist目录下的文件可以部署到Nginx服务器。以下是Nginx配置示例server { listen 80; server_name yourdomain.com; location / { root /path/to/ruoyi-ui/dist; index index.html index.htm; try_files $uri $uri/ /index.html; } location /prod-api/ { proxy_pass http://localhost:8080/; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; } error_page 500 502 503 504 /50x.html; location /50x.html { root html; } }5.2 后端打包与部署后端使用Maven打包mvn clean package -Dmaven.test.skiptrue打包完成后ruoyi-admin/target目录下会生成可执行的jar文件。可以使用以下命令启动java -jar ruoyi-admin.jar --spring.profiles.activeprod对于生产环境建议使用Docker容器化部署创建DockerfileFROM openjdk:8-jdk-alpine VOLUME /tmp COPY ruoyi-admin.jar app.jar ENTRYPOINT [java,-Djava.security.egdfile:/dev/./urandom,-jar,/app.jar]构建并运行容器docker build -t ruoyi-admin . docker run -d -p 8080:8080 --name ruoyi ruoyi-admin5.3 性能优化建议数据库优化为常用查询字段添加合适索引对大表考虑分表分库策略定期执行ANALYZE TABLE更新统计信息前端优化启用Gzip压缩减少传输体积使用CDN加速静态资源加载按需加载组件减少初始包大小后端优化配置合理的线程池参数启用二级缓存减少数据库访问对热点数据使用Redis缓存// Spring Cache配置示例 Configuration EnableCaching public class CacheConfig { Bean public CacheManager cacheManager(RedisConnectionFactory factory) { RedisCacheConfiguration config RedisCacheConfiguration.defaultCacheConfig() .entryTtl(Duration.ofMinutes(30)) .disableCachingNullValues(); return RedisCacheManager.builder(factory) .cacheDefaults(config) .transactionAware() .build(); } }在实际项目中根据监控数据持续优化系统性能是关键。可以使用Spring Boot Actuator暴露监控端点结合Prometheus和Grafana建立可视化监控系统。

相关文章:

Ruoyi-Vue3实战:10分钟搞定学生管理系统CRUD(附完整SQL)

Ruoyi-Vue3学生管理系统实战:从零到部署的完整指南 在当今快速迭代的开发环境中,选择高效的技术栈至关重要。Ruoyi-Vue3作为基于Spring Boot和Vue3的企业级开发框架,以其模块化设计和丰富的功能组件,成为快速构建管理系统的首选方…...

告别手动截图!用Python脚本从ROS bag文件里精准提取带时间戳的图片(附完整代码)

告别手动截图!用Python脚本从ROS bag文件里精准提取带时间戳的图片(附完整代码) 在计算机视觉和机器人研究中,从ROS bag文件中高效提取带时间戳的图像数据是构建数据集的关键步骤。传统方法依赖ROS自带工具,但常面临提…...

旧iOS设备维护全流程解决方案:Legacy iOS Kit实用指南

旧iOS设备维护全流程解决方案:Legacy iOS Kit实用指南 【免费下载链接】Legacy-iOS-Kit An all-in-one tool to downgrade/restore, save SHSH blobs, and jailbreak legacy iOS devices 项目地址: https://gitcode.com/gh_mirrors/le/Legacy-iOS-Kit Legacy…...

BinCmdParser:嵌入式二进制命令动态解析器

1. BinCmdParser:面向嵌入式通信的动态二进制命令解析器 在工业控制、传感器网络与跨平台设备互联场景中,串口/UART/SPI/I2C等低带宽物理通道常承载结构化二进制指令。传统固定帧格式(如Modbus RTU、自定义8字节头4字节长度2字节CRC&#xff…...

别再手动推导了!用Sophus库5分钟搞定机器人SLAM中的位姿插值与扰动更新

别再手动推导了!用Sophus库5分钟搞定机器人SLAM中的位姿插值与扰动更新 在机器人SLAM开发中,你是否曾为手动推导旋转矩阵的插值公式而抓狂?是否在实现位姿扰动更新时被四元数微分弄得晕头转向?今天,我们将用Sophus库彻…...

【多模态技术解析】先对齐再融合:动量蒸馏如何重塑视觉与语言表征学习

1. 为什么视觉和语言要先对齐再融合? 想象一下你正在教一个小朋友认识动物。如果先给他看一张猫的图片,再告诉他"这是狗",小朋友肯定会困惑。这就是典型的模态未对齐问题——视觉信息和语言信息没有正确匹配。在多模态AI领域&#…...

银发健康消费“新战场”:线下渠道红利期开启,10+嘉宾重磅分享实战方法论

​银发经济与连锁药店转型的双向奔赴整理 | AgeClub内容团队前言当前,中国银发经济已成为国内增长最快的赛道之一。数据显示,我国银发经济市场规模已突破 10 万亿元,未来整体规模有望超过 30 万亿元。精准对接优质渠道,成为众多银…...

Windows系统下Neo4j社区版手动安装与配置指南(非Docker方案)

1. 环境准备:JDK安装与验证 在Windows系统下手动安装Neo4j社区版,第一步就是搞定Java环境。我见过太多新手卡在这一步,其实只要注意几个关键点就能轻松过关。Neo4j作为基于Java开发的图数据库,必须依赖JDK才能运行,但不…...

ESP32/ESP8266轻量级HA MQTT自动发现C++库

1. 项目概述 HA MQTT Discovery 是一个专为嵌入式平台(特别是 ESP32/ESP8266)设计的轻量级 C 库,用于实现与 Home Assistant 的原生 MQTT 自动发现(Auto-Discovery)协议兼容的设备与实体注册。其核心目标并非替代完整…...

Arduino蓝牙TPMS解析库:7字节广告数据逆向与嵌入式解码实践

1. BluetoothTPMS 库技术解析:面向嵌入式系统的蓝牙胎压监测数据解码实践1.1 项目定位与工程价值BluetoothTPMS 是一个专为 Arduino 平台设计的轻量级开源库,核心目标是实现对低成本商用 TPMS(Tire Pressure Monitoring System)传…...

别再乱调灯光和材质了!UE5渲染性能优化的三个核心禁忌与正确姿势

UE5渲染性能优化的三大禁忌与实战解决方案 在虚幻引擎5的渲染管线中,性能优化往往成为项目后期最棘手的挑战之一。许多开发者习惯性地将注意力集中在视觉效果上,却忽略了渲染效率的平衡。当场景复杂度达到临界点时,那些看似无害的高精度贴图…...

TwinCAT3-UDP自定义协议实现高效点对点通信

1. TwinCAT3-UDP通信基础与场景解析 在工业自动化领域,设备间的高效数据交换一直是工程师们关注的焦点。TwinCAT3作为倍福(Beckhoff)推出的自动化软件平台,其UDP通信功能为点对点数据传输提供了轻量级解决方案。与TCP协议相比&…...

**NPU设计新范式:基于RISC-V的可配置计算单元实现与性能优化实践**在人工智能加速领域,

NPU设计新范式:基于RISC-V的可配置计算单元实现与性能优化实践 在人工智能加速领域,NPU(神经网络处理单元) 正从专用硬件向灵活可编程架构演进。本文将深入探讨一种基于 RISC-V指令集扩展 的轻量级NPU设计方案,并通过实…...

LangChain工具绑定避坑指南:为什么你的bind_tools不工作?

LangChain工具绑定深度解析:从原理到实战的避坑指南 当你第一次尝试在LangChain中绑定自定义工具时,可能会遇到各种令人困惑的问题——工具明明定义了却无法调用,参数传递总是出错,或者LLM完全无视你的工具指令。这些问题往往不是…...

从网吧到企业网:静态路由在小型网络中的3种典型应用场景

从网吧到企业网:静态路由在小型网络中的3种典型应用场景 在当今数字化商业环境中,网络连通性已成为各类企业运营的基础需求。对于中小型商业场所如连锁网吧、零售分店或小微企业分支机构而言,如何在有限预算下构建稳定可靠的网络架构&#xf…...

为什么我的Flowbite样式不生效?Tailwind CSS配置避坑与Svelte项目优化技巧

为什么我的Flowbite样式不生效?Tailwind CSS配置避坑与Svelte项目优化技巧 在Svelte项目中集成Flowbite组件库时,开发者常会遇到样式不生效的问题。这通常不是Flowbite本身的缺陷,而是配置环节的疏漏或构建工具的特定行为导致的。本文将深入剖…...

简单认识了解MSE

了解MSE 的应用场景在传统的网页开发中,前端处理视频的方式非常被动:给 video标签指定一个src,剩下的下载、缓冲、解码工作完全由浏览器底层“黑盒”接管,开发者几乎无法干预。MSE(Media Source Extensions&#xff0c…...

保姆级教程:用Qt的QNetworkAccessManager实现网络延迟与带宽的简易测试工具(附完整源码)

从零构建Qt网络性能测试工具:延迟与带宽测量的实战指南 在开发网络应用时,我们常常需要了解当前网络环境对应用性能的影响。无论是评估服务器响应速度,还是测试用户在不同网络条件下的体验,一个轻量级的网络测试工具都能派上大用场…...

5分钟搞懂MTMCT:多目标多摄像头跟踪的实战应用与避坑指南

5分钟搞懂MTMCT:多目标多摄像头跟踪的实战应用与避坑指南 想象一下这样的场景:当你走进一家大型超市,天花板上数十个摄像头正无声地记录着每个顾客的移动轨迹。如何确保系统能准确识别同一个人在不同摄像头间的切换?这就是多目标多…...

springboot+vue基于web的酒店客房预订管理系统

目录同行可拿货,招校园代理 ,本人源头供货商系统功能模块划分核心技术实现数据交互设计扩展功能建议项目技术支持源码获取详细视频演示 :文章底部获取博主联系方式!同行可合作同行可拿货,招校园代理 ,本人源头供货商 系统功能模块划分 后端&#xff08…...

百考通:AI全流程智能化驱动数据分析,让数据价值高效落地

在数字化浪潮席卷各行各业的今天,数据已成为核心生产要素,但如何从海量数据中挖掘价值、辅助决策,始终是企业与个人面临的核心难题。传统数据分析流程繁琐、技术门槛高、周期漫长,让许多非专业人士望而却步。百考通(ht…...

程序员必看!用UML类图破解Spring Boot领域模型设计难题

程序员必看!用UML类图破解Spring Boot领域模型设计难题 在Spring Boot项目中,领域模型设计往往是决定系统可维护性和扩展性的关键。许多Java开发者虽然熟练使用JPA和MyBatis,但当面对复杂的业务逻辑时,却常常陷入"贫血模型&q…...

避开高光谱求导的坑:你的平滑做对了吗?附MATLAB代码与数据示例

高光谱微分预处理实战指南:如何避免噪声放大陷阱 第一次处理高光谱数据时,我兴奋地直接对原始光谱曲线求导,结果得到了一堆杂乱无章的噪声信号。这个教训让我明白了一个关键原则:未经平滑的微分操作就像在放大镜下观察指纹——细节…...

S7通信避坑指南:当1200/1500 PLC遇上S7-200 SMART,这些数据类型和地址映射坑你别踩

S7通信实战避坑手册:跨越1200/1500与200 SMART的数据鸿沟 在工业自动化系统升级改造过程中,新旧设备混合组网已成为常态。当工程师面对S7-1200/1500与S7-200 SMART的异构通信需求时,往往会陷入数据类型转换、地址映射等"隐形陷阱"。…...

百考通:AI全流程智能化赋能,让每一份调研与设计都高效落地

在数字化时代,市场调研、产品设计、学术研究等场景中,问卷设计作为核心环节,直接影响着数据收集的质量与工作推进的效率。传统问卷设计往往面临流程繁琐、耗时耗力、问题设计不精准等痛点,而百考通(https://www.baikao…...

Linux服务器上Ollama离线安装全攻略(附systemd服务配置)

Linux服务器上Ollama离线安装全攻略(附systemd服务配置) 在企业内网或实验室环境中,离线部署AI工具往往面临诸多挑战。本文将手把手带你完成Ollama在Linux服务器上的完整离线安装流程,特别针对无外网访问权限的场景优化&#xff0…...

5分钟快速部署!终极开源邮件营销平台BillionMail完全指南 [特殊字符]

5分钟快速部署!终极开源邮件营销平台BillionMail完全指南 🚀 【免费下载链接】BillionMail Billion Mail is a future open-source email marketing platform designed to help businesses and individuals manage their email campaigns with ease 项…...

FOIL框架实战:用不变学习破解时间序列预测的OOD难题

1. 当时间序列预测遇上OOD难题:从业务痛点说起 去年冬天,我接手了一个零售销量预测项目。客户兴奋地展示着他们在历史数据上达到95%准确率的LSTM模型,但实际部署后,这个"明星模型"在新年促销季的预测误差突然飙升到40%。…...

从YOLO到A*:手把手教你用PyTorch和OpenCV搭建一个简易的自动驾驶避障仿真器

从YOLO到A*:用PyTorch和OpenCV构建自动驾驶避障仿真器 想象一下,你正坐在一辆自动驾驶汽车里,车辆能够自动识别前方的行人、车辆和障碍物,并规划出安全的行驶路径。这种看似科幻的场景,如今正逐渐成为现实。本文将带你…...

嵌入式开发中开源组件的战略价值与使用策略

1. 嵌入式开发中开源组件的战略价值在当今嵌入式系统开发领域,开源软件已经成为不可或缺的战略资源。作为一名从业十余年的嵌入式工程师,我亲眼见证了开源生态如何彻底改变这个行业的开发模式。从早期的闭源商业解决方案主导,到现在几乎每个项…...