12- 【JavaWeb】校园快递管理系统-数据库建设
项目概述
开发一个Javaweb校园快递管理系统,包含以下功能:
-
数据库设计
- 首先,我们需要设计数据库的表结构。主要包括以下表:
- 学生表: 存储学生的基本信息,姓名、手机号。
- 快递表: 存储快递的信息,快递单号、收件人、收件人手机号、快递状态等。
- 管理员表: 存储管理员的登录信息,用户名、密码。
- 日志表: 存储系统操作的日志信息,操作时间、操作内容、操作人员。
- 首先,我们需要设计数据库的表结构。主要包括以下表:
-
在线录入学生和快递信息
- 在前端页面上设计一个表单,用于录入学生和快递的信息。
- 将表单数据通过HTTP请求发送到后端服务,由后端将数据保存到数据库中。
- 前端使用HTML、CSS和JavaScript来实现表单的设计和数据的提交。后端使用Java来处理HTTP请求并操作数据库。
-
查询每日到达的快递列表及未取件快递
- 在前端页面上设计一个快递查询区域,可以按照收件日期和快递状态进行筛选。
- 后端查询数据库,返回符合条件的快递信息。前端将这些信息显示在页面上。
- 使用列表的形式来展示快递信息。
-
查询每个学生的快递列表
- 在前端页面上设计一个学生快递查询区域,可以根据姓名或者手机号进行查询。
- 后端查询数据库,返回该学生所有的快递信息。前端将这些信息显示在页面上。
- 使用列表的形式来展示快递信息。
-
完整的日志系统
- 在每次操作数据库时,将操作信息记录到日志表中。
- 在前端页面上设计一个日志查询区域,可以按照操作时间、操作内容和操作人员进行筛选。
- 后端查询数据库,返回符合条件的日志信息。前端将这些信息显示在页面上。
- 可以使用表格或列表的形式来展示日志信息。
-
管理员的登录和退出
- 在前端页面上设计一个登录界面,要求输入用户名和密码。
- 后端验证登录信息是否正确,如果正确则返回登录成功的标识。前端根据这个标识来决定是否显示管理员功能。
- 在前端页面上设计一个退出按钮,点击后清除登录状态,返回到普通用户界面。
-
快递浏览,入库新快递,删除过期快递
- 在前端页面上设计一个快递管理区域,包括浏览、入库和删除功能。
- 浏览功能可以显示所有已入库的快递信息。
- 入库功能可以录入新收到的快递信息。
- 删除功能可以删除已过期的快递信息。
- 上述功能只有管理员才能操作。
第一步:数据库设计
首先,我们设计一个简单的数据库结构来存储系统的相关数据。这里我们使用MySQL作为数据库。
CREATE DATABASE express_management;
USE express_management;
1.1 学生表 (student)
CREATE TABLE student (student_id INT PRIMARY KEY AUTO_INCREMENT,name VARCHAR(50) NOT NULL,phone VARCHAR(20) NOT NULL,UNIQUE (phone) -- 确保手机号唯一
);
字段解释:
student_id:学生的唯一标识,主键,自增。name:学生姓名。phone:学生的手机号,设为唯一,防止重复录入。
1.2 快递表 (express)
CREATE TABLE express (express_id INT PRIMARY KEY AUTO_INCREMENT,tracking_number VARCHAR(50) NOT NULL UNIQUE, -- 快递单号recipient_id INT NOT NULL, -- 收件人id,关联student表recipient_phone VARCHAR(20) NOT NULL, -- 收件人手机号status VARCHAR(20) NOT NULL, -- 快递状态(未取件、已取件)arrival_date DATE NOT NULL, -- 到达时间FOREIGN KEY (recipient_id) REFERENCES student(student_id) -- 外键关联student表
);
字段解释:
express_id:快递的唯一标识,主键,自增。tracking_number:快递单号,设为唯一,防止重复。recipient_id:收件人的学生ID,外键关联student表。recipient_phone:收件人的手机号,冗余存储方便查询。status:快递的状态(如"未取件"、“已取件”)。arrival_date:快递的到达日期。
1.3 管理员表 (admin)
CREATE TABLE admin (admin_id INT PRIMARY KEY AUTO_INCREMENT,username VARCHAR(50) NOT NULL UNIQUE,password VARCHAR(100) NOT NULL -- 密码可以加密存储
);
字段解释:
admin_id:管理员的唯一标识,主键,自增。username:管理员的用户名,设为唯一,防止重复。password:管理员的密码,建议在实际项目中存储加密后的密码。
1.4 日志表 (log)
CREATE TABLE log (log_id INT PRIMARY KEY AUTO_INCREMENT,operation_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP, -- 操作时间operation_content VARCHAR(255) NOT NULL, -- 操作内容operator_id INT NOT NULL, -- 操作者ID(关联管理员ID)FOREIGN KEY (operator_id) REFERENCES admin(admin_id) -- 外键关联admin表
);
字段解释:
log_id:日志的唯一标识,主键,自增。operation_time:操作的时间,默认使用当前时间。operation_content:操作的具体内容描述。operator_id:操作人员的管理员ID,外键关联admin表。
检查数据库和表的创建是否成功,可以按照以下步骤进行验证:
1. 检查数据库是否创建成功
在MySQL命令行或数据库管理工具中执行以下命令:
SHOW DATABASES;
在返回的列表中,查看是否包含 express_management 数据库。
2. 使用数据库
确保你已经选择了刚刚创建的数据库:
USE express_management;
3. 检查表是否创建成功
执行以下命令,查看当前数据库中的所有表:
SHOW TABLES;
返回的结果中应该包含以下表:
studentexpressadminlog
4. 验证每个表的结构
你可以使用 DESCRIBE 命令来检查每个表的结构,确认表的字段及其属性是否正确。
检查学生表 (student)
DESCRIBE student;
确认字段如下:
student_id(INT, AUTO_INCREMENT, PRIMARY KEY)name(VARCHAR(50), NOT NULL)phone(VARCHAR(20), NOT NULL, UNIQUE)
检查快递表 (express)
DESCRIBE express;
确认字段如下:
express_id(INT, AUTO_INCREMENT, PRIMARY KEY)tracking_number(VARCHAR(50), NOT NULL, UNIQUE)recipient_id(INT, NOT NULL, FOREIGN KEY)recipient_phone(VARCHAR(20), NOT NULL)status(VARCHAR(20), NOT NULL)arrival_date(DATE, NOT NULL)
检查管理员表 (admin)
DESCRIBE admin;
确认字段如下:
admin_id(INT, AUTO_INCREMENT, PRIMARY KEY)username(VARCHAR(50), NOT NULL, UNIQUE)password(VARCHAR(100), NOT NULL)
检查日志表 (log)
DESCRIBE log;
确认字段如下:
log_id(INT, AUTO_INCREMENT, PRIMARY KEY)operation_time(TIMESTAMP, DEFAULT CURRENT_TIMESTAMP)operation_content(VARCHAR(255), NOT NULL)operator_id(INT, NOT NULL, FOREIGN KEY)
相关文章:
12- 【JavaWeb】校园快递管理系统-数据库建设
项目概述 开发一个Javaweb校园快递管理系统,包含以下功能: 数据库设计 首先,我们需要设计数据库的表结构。主要包括以下表: 学生表: 存储学生的基本信息,姓名、手机号。快递表: 存储快递的信息,快递单号、收件人、收件人手机号、…...
Windows本地连接远程服务器并创建新用户详细记录
前提可知: (1)服务器IP地址:x.x.x.x (2)服务器名称:root(一般默认为root,当然也有别的名称) (3)服务器登陆密码:**** 一、…...
【kaggle竞赛】毒蘑菇的二元预测题目相关信息和思路求解代码
毒蘑菇的二元预测 您提供了很多关于不同二元分类任务的资源和链接,看起来这些都是Kaggle竞赛中的参考资料和高分解决方案。为了帮助您更好地利用这些资源,这里是一些关键点的总结: Playground Season 4 Episode 8 主要关注的竞赛: 使用银行…...
Pytest-allure如何在测试完成后自动生成完整报告?
一、完整步骤 常规allure报告的生成方法是在pytest全部用例执行完成后,手动在命令行执行如 allure generate ./temps -o ./report --clean每次用例执行完成后都要重复如此的操作,十分繁琐。 可以使用如下方式让用例执行完成后自动生成报告到当前目录下…...
数据结构-树(基础,分类,遍历)
数据结构-树 1.什么是树? 在计算机科学中,树是一种常用的非线性数据结构,用于表示具有层次关系的数据。与线性数据结构(如数组和链表)不同,树结构以节点(Nodes)和边(Ed…...
CodeGeeX4:程序员的高效助手,多语言代码生成神器!
你是否曾在编写代码时,为复杂的语法、逻辑错误而绞尽脑汁?或是在面对多个编程语言的切换时,感觉脑子快要爆炸?别担心!一款全新的多语言代码生成神器——CodeGeeX4,正悄然成为程序员们的“救命稻草”。它不仅…...
小程序组件间通信
文章目录 父传子子传父获取组件实例兄弟通信 父传子 知识点: 父组件如果需要向子组件传递指定属性的数据,在 WXML 中需要使用数据绑定的方式 与普通的 WXML 模板类似,使用数据绑定,这样就可以向子组件的属性传递动态数据。 父…...
Homebrew安装与切换下载源
一、安装 1.Homebrew的官网地址 https://brew.sh/zh-cn/ 2.执行命令行安装 /bin/bash -c “$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)” 3.无法连接到https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh的地址 解决…...
C#回调函数
1、定义并初始化委托 public delegate void CallbackDelegate(string message);//定义一个委托类型CallbackDelegate callbackDelegate;//声明一个委托对象/// <summary>/// 定义委托对应的函数/// </summary>/// <param name"str"></param>…...
Matplotlib绘制热力图
热力图(Heatmap)是一种使用颜色来表示数值强度的数据可视化工具。它常用于以下场景: 热力图的适用场景 数据的相关性分析:在统计学中,热力图常用于展示变量之间的相关性,尤其是当数据量较大时,…...
手写SpringMVC
1、开发HspDispatcherServlet 2、完成客户端/浏览器可以请求控制层 目的:发出url请求时,经过前端控制器,找到Monster的List方法,把结果再打回去 3、从web.xml动态获取hspspringmvc.xml 4、完成自定义Service注解功能 目的&…...
mysql学习教程,从入门到精通,SQL 删除数据(DELETE 语句)(18)
1、SQL 删除数据(DELETE 语句) 在编写SQL中的DELETE语句时,需要非常小心,因为一旦执行,被删除的数据就无法恢复了(除非你有备份)。DELETE语句用于从数据库表中移除一条或多条记录。这里&#x…...
周边游小程序开发
开发一个周边游小程序是一个既有趣又富有挑战性的项目,它可以帮助用户发现周边的旅游景点、活动、美食和住宿等,提升用户的旅游体验。以下是开发周边游小程序的基本步骤和一些建议: 1.市场调研与需求分析 目标用户定位:确定你的用…...
初级前端面试
1.介绍自己 2.介绍一下之前做过的项目以及接触的业务 3.最近学的技术,接触的是哪一块(回答了vue3) 4.vue3在什么时候调用接口 beforeCreate 在实例初始化之后,数据观测 (data observer) 和 event/watcher 事件配置之前被调用。 用…...
微软AI核电计划
每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗?订阅我们的简报,深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同,从行业内部的深度分析和实用指南中受益。不要错过这个机会,成为AI领…...
图片马赛克处理(Java)
1.需求 给图片的指定区域打码给整张图片打码马赛克方格取色支持中心点取色和随机取色马赛克支持灰度处理 2.源码 package com.visy.utils;import javax.imageio.ImageIO; import java.awt.*; import java.awt.image.BufferedImage; import java.io.File; import java.io.IOE…...
python+selenium实现自动联网认证,并实现断网重连
pythonselenium实现自动联网认证,并实现断网重连 echo off python “E:\autoD\auto_login.py” 要使自动登录脚本在系统重启后自动运行,你可以使用Windows的任务计划程序来设置。以下是详细的步骤: 1. 保存脚本 首先,将你的Py…...
基于机器学习的注意力缺陷/多动障碍 (ADHD)(python论文+代码)HYPERAKTIV
简述 医疗保健领域的机器学习研究往往缺乏完全可重复性和可比性所需的公共数据。由于患者相关数据附带的隐私问题和法律要求,数据集往往受到限制。因此,许多算法和模型发表在同一主题上,没有一个标准的基准。因此,本文提出了一个公…...
Spring Boot 集成 Redisson 实现消息队列
包含组件内容 RedisQueue:消息队列监听标识RedisQueueInit:Redis队列监听器RedisQueueListener:Redis消息队列监听实现RedisQueueService:Redis消息队列服务工具 代码实现 RedisQueue import java.lang.annotation.ElementTyp…...
go语言Map详解
Map Go语言中提供的映射关系容器为map,其内部使用散列表(hash)实现 map是一种无序的基于key-value的数据结构,Go语言中的map是引用类型,必须初始化才能使用。 它提供了高效的查找、插入和删除操作,非常适…...
Xshell远程连接Kali(默认 | 私钥)Note版
前言:xshell远程连接,私钥连接和常规默认连接 任务一 开启ssh服务 service ssh status //查看ssh服务状态 service ssh start //开启ssh服务 update-rc.d ssh enable //开启自启动ssh服务 任务二 修改配置文件 vi /etc/ssh/ssh_config //第一…...
基于ASP.NET+ SQL Server实现(Web)医院信息管理系统
医院信息管理系统 1. 课程设计内容 在 visual studio 2017 平台上,开发一个“医院信息管理系统”Web 程序。 2. 课程设计目的 综合运用 c#.net 知识,在 vs 2017 平台上,进行 ASP.NET 应用程序和简易网站的开发;初步熟悉开发一…...
【Zephyr 系列 10】实战项目:打造一个蓝牙传感器终端 + 网关系统(完整架构与全栈实现)
🧠关键词:Zephyr、BLE、终端、网关、广播、连接、传感器、数据采集、低功耗、系统集成 📌目标读者:希望基于 Zephyr 构建 BLE 系统架构、实现终端与网关协作、具备产品交付能力的开发者 📊篇幅字数:约 5200 字 ✨ 项目总览 在物联网实际项目中,**“终端 + 网关”**是…...
BCS 2025|百度副总裁陈洋:智能体在安全领域的应用实践
6月5日,2025全球数字经济大会数字安全主论坛暨北京网络安全大会在国家会议中心隆重开幕。百度副总裁陈洋受邀出席,并作《智能体在安全领域的应用实践》主题演讲,分享了在智能体在安全领域的突破性实践。他指出,百度通过将安全能力…...
如何在最短时间内提升打ctf(web)的水平?
刚刚刷完2遍 bugku 的 web 题,前来答题。 每个人对刷题理解是不同,有的人是看了writeup就等于刷了,有的人是收藏了writeup就等于刷了,有的人是跟着writeup做了一遍就等于刷了,还有的人是独立思考做了一遍就等于刷了。…...
【SSH疑难排查】轻松解决新版OpenSSH连接旧服务器的“no matching...“系列算法协商失败问题
【SSH疑难排查】轻松解决新版OpenSSH连接旧服务器的"no matching..."系列算法协商失败问题 摘要: 近期,在使用较新版本的OpenSSH客户端连接老旧SSH服务器时,会遇到 "no matching key exchange method found", "n…...
【C++特殊工具与技术】优化内存分配(一):C++中的内存分配
目录 一、C 内存的基本概念 1.1 内存的物理与逻辑结构 1.2 C 程序的内存区域划分 二、栈内存分配 2.1 栈内存的特点 2.2 栈内存分配示例 三、堆内存分配 3.1 new和delete操作符 4.2 内存泄漏与悬空指针问题 4.3 new和delete的重载 四、智能指针…...
C# 表达式和运算符(求值顺序)
求值顺序 表达式可以由许多嵌套的子表达式构成。子表达式的求值顺序可以使表达式的最终值发生 变化。 例如,已知表达式3*52,依照子表达式的求值顺序,有两种可能的结果,如图9-3所示。 如果乘法先执行,结果是17。如果5…...
Python网页自动化Selenium中文文档
1. 安装 1.1. 安装 Selenium Python bindings 提供了一个简单的API,让你使用Selenium WebDriver来编写功能/校验测试。 通过Selenium Python的API,你可以非常直观的使用Selenium WebDriver的所有功能。 Selenium Python bindings 使用非常简洁方便的A…...
自然语言处理——文本分类
文本分类 传统机器学习方法文本表示向量空间模型 特征选择文档频率互信息信息增益(IG) 分类器设计贝叶斯理论:线性判别函数 文本分类性能评估P-R曲线ROC曲线 将文本文档或句子分类为预定义的类或类别, 有单标签多类别文本分类和多…...
