完成一个数据库课设包含SQL代码

时间: 2024-05-18 19:15:14 浏览: 99
好的,以下是一个简单的学生信息管理系统的数据库课设,包含 SQL 代码: 1. 数据库设计 学生表(students): | 字段名 | 数据类型 | 约束 | 说明 | | ------------ | -------------- | -------- | -------------- | | id | int | 主键 | 学生编号 | | name | varchar(20) | 非空 | 学生姓名 | | gender | varchar(2) | 非空 | 学生性别 | | birthday | date | 非空 | 学生出生日期 | | department | varchar(50) | 非空 | 学生所属院系 | | major | varchar(50) | 非空 | 学生所属专业 | | grade | varchar(4) | 非空 | 学生所属年级 | | class | varchar(10) | 非空 | 学生所属班级 | | phone_number | varchar(20) | | 学生联系电话 | | address | varchar(100) | | 学生家庭地址 | 课程表(courses): | 字段名 | 数据类型 | 约束 | 说明 | | ---------- | ----------- | -------- | ---------- | | id | int | 主键 | 课程编号 | | name | varchar(50) | 非空 | 课程名称 | | credit | float | 非空 | 课程学分 | | teacher | varchar(20) | 非空 | 授课教师 | | department | varchar(50) | 非空 | 课程所属院 | | time | varchar(50) | 非空 | 课程时间 | | place | varchar(50) | 非空 | 课程地点 | 成绩表(scores): | 字段名 | 数据类型 | 约束 | 说明 | | ---------- | -------- | -------- | ---------- | | id | int | 主键 | 成绩编号 | | student_id | int | 外键 | 学生编号 | | course_id | int | 外键 | 课程编号 | | score | float | | 学生成绩 | | exam_time | date | | 考试时间 | | exam_type | varchar | 非空 | 考试类型 | | note | varchar | | 成绩备注 | 2. 数据库实现 -- 创建数据库 CREATE DATABASE student_management; -- 选择数据库 USE student_management; -- 创建学生表 CREATE TABLE students ( id int PRIMARY KEY, name varchar(20) NOT NULL, gender varchar(2) NOT NULL, birthday date NOT NULL, department varchar(50) NOT NULL, major varchar(50) NOT NULL, grade varchar(4) NOT NULL, class varchar(10) NOT NULL, phone_number varchar(20), address varchar(100) ); -- 创建课程表 CREATE TABLE courses ( id int PRIMARY KEY, name varchar(50) NOT NULL, credit float NOT NULL, teacher varchar(20) NOT NULL, department varchar(50) NOT NULL, time varchar(50) NOT NULL, place varchar(50) NOT NULL ); -- 创建成绩表 CREATE TABLE scores ( id int PRIMARY KEY, student_id int, course_id int, score float, exam_time date, exam_type varchar(20) NOT NULL, note varchar(100), FOREIGN KEY (student_id) REFERENCES students(id), FOREIGN KEY (course_id) REFERENCES courses(id) ); -- 插入学生数据 INSERT INTO students VALUES (1, '张三', '男', '1998-01-01', '计算机科学与技术学院', '计算机科学与技术', '2017', '1班', '18812345678', '北京市海淀区'), (2, '李四', '女', '1999-02-02', '软件工程学院', '软件工程', '2018', '2班', '17712345678', '北京市朝阳区'); -- 插入课程数据 INSERT INTO courses VALUES (1, '数据库原理', 3.0, '张老师', '计算机科学与技术学院', '周一1-3节', '教学楼102'), (2, 'Java程序设计', 4.0, '李老师', '软件工程学院', '周二1-4节', '教学楼103'); -- 插入成绩数据 INSERT INTO scores VALUES (1, 1, 1, 80, '2020-01-01', '期末考试', NULL), (2, 1, 2, 90, '2020-01-02', '期末考试', NULL), (3, 2, 1, 85, '2020-01-01', '期末考试', NULL), (4, 2, 2, 95, '2020-01-02', '期末考试', NULL); 3. 数据库查询 -- 查询所有学生信息 SELECT * FROM students; -- 查询所有课程信息 SELECT * FROM courses; -- 查询所有学生成绩 SELECT * FROM scores; -- 查询张三的所有成绩 SELECT scores.*, courses.name FROM scores, courses WHERE scores.student_id = 1 AND scores.course_id = courses.id; -- 查询数据库中所有学生所属的院系 SELECT DISTINCT department FROM students; -- 查询计算机科学与技术学院的学生信息 SELECT * FROM students WHERE department = '计算机科学与技术学院'; -- 查询所有学生的平均成绩 SELECT AVG(score) FROM scores; -- 查询所有学生的平均成绩,并按照成绩降序排序 SELECT AVG(score) AS avg_score FROM scores GROUP BY student_id ORDER BY avg_score DESC; -- 查询所有学生的平均成绩,并按照成绩降序排序,只显示前三个学生 SELECT AVG(score) AS avg_score FROM scores GROUP BY student_id ORDER BY avg_score DESC LIMIT 3; 4. 数据库维护 -- 备份数据库 mysqldump -u root -p student_management > student_management.sql -- 优化数据库性能 ANALYZE TABLE students; ANALYZE TABLE courses; ANALYZE TABLE scores; -- 修复数据库错误 REPAIR TABLE students; REPAIR TABLE courses; REPAIR TABLE scores;
阅读全文

相关推荐

最新推荐

recommend-type

数据库课程设计 sql server2005 c# 课设

**SQL Server 2005** 是微软公司推出的一款关系型数据库管理系统,它提供了强大的数据存储、查询和管理功能。在课程设计中,SQL Server 2005被用于构建和管理数据库,包括数据的增删改查、事务处理、索引设计和性能...
recommend-type

基于Java+sql教师信息管理系统课设报告

【基于Java+SQL的教师信息管理系统】是一个典型的数据库应用系统,用于管理教师的相关信息,包括登录、退出、信息增删改查等基本操作。系统主要采用Java编程语言进行设计,结合SQL数据库技术来存储和处理数据。 在*...
recommend-type

PB数据库 车站售票系统源代码

对于学习数据库设计和PB编程的学生来说,这是一个很好的实践案例,可以帮助他们理解和应用数据库理论知识,如关系型数据库的操作、事务处理以及用户界面交互。同时,该系统也体现了在实际业务场景中如何处理数据验证...
recommend-type

华东大学 SQL数据库课程设计 (论文)

【SQL数据库课程设计】在华东交通大学的软件学院网络工程专业二班中,学生们被分配了一项重要的课程设计任务——构建一个小型公司的工资管理系统。这项任务旨在让学生深入理解和应用面向对象编程的思想,特别是结合...
recommend-type

数据库图书管理系统课设报告 C#语言 数据库

本课设报告涉及的是一个使用C#语言开发的图书管理系统,该系统针对数据库课程设计,目的是实现对图书、学生信息以及借阅流程的有效管理。以下是系统的详细描述和相关知识点: 1. **系统架构与功能设计** - 系统...
recommend-type

Elasticsearch核心改进:实现Translog与索引线程分离

资源摘要信息:"Elasticsearch是一个基于Lucene构建的开源搜索引擎。它提供了一个分布式多用户能力的全文搜索引擎,基于RESTful web接口。Elasticsearch是用Java语言开发的,并作为Apache许可条款下的开源项目发布,是当前流行的企业级搜索引擎。设计用于云计算中,能够达到实时搜索,稳定,可靠,快速,安装使用方便。" "Elasticsearch的索引线程是处理索引操作的重要部分,负责处理数据的写入、更新和删除等操作。但是,在处理大量数据和高并发请求时,如果索引线程处理速度过慢,就会导致数据处理的延迟,影响整体性能。因此,Elasticsearch采用了事务日志(translog)机制来提高索引操作的效率和可靠性。" "Elasticsearch的事务日志(translog)是一种持久化存储机制,用于记录所有未被持久化到分片中的索引操作。在发生故障或系统崩溃时,事务日志可以确保所有索引操作不会丢失,保证数据的完整性。每个分片都有自己的事务日志文件。" "在Elasticsearch的早期版本中,事务日志的操作和索引线程的操作是在同一个线程中完成的,这可能会导致性能瓶颈。为了解决这个问题,Elasticsearch将事务日志的操作从索引线程中分离出去,使得索引线程可以专注于数据的索引操作,而事务日志的操作可以独立地进行。这样可以大大提高了Elasticsearch的索引性能。" "但是,事务日志的操作是独立于索引操作的,这就需要保证事务日志的操作不会影响到索引操作的性能。因此,在将事务日志从索引线程分离出去的同时,Elasticsearch也引入了一些优化策略,比如批量写入事务日志,减少磁盘I/O操作,以及优化事务日志的数据结构,提高读写效率等。" "需要注意的是,虽然事务日志的分离可以提高索引操作的性能,但是也会增加系统的复杂度和维护难度。因此,开发者在使用这个功能时,需要充分理解其原理和影响,才能确保系统的稳定运行。" "此外,由于这个功能还处于测试和学习阶段,尚未被广泛应用于生产环境,所以开发者在使用时需要谨慎,避免对生产环境造成影响。" "总的来说,Elasticsearch的事务日志的分离是一个重要的优化,可以大大提升索引操作的性能,但是在使用时也需要充分考虑其带来的影响,才能确保系统的稳定运行。"
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

病房呼叫系统设计基础:7个关键架构策略让你一步入门

![病房呼叫系统设计基础:7个关键架构策略让你一步入门](https://zektek.com.mx/wp-content/uploads/2021/03/diagram-enfermeria.jpg) # 摘要 本文对病房呼叫系统进行了深入的概述、需求分析、架构设计、功能实现以及实践应用案例的探讨。通过分析系统架构的重要性、设计原则、模块划分和数据流,确保了系统的高效运行和优化。本文进一步探讨了呼叫信号传输技术、显示与反馈机制、系统安全性与可靠性设计,并分析了系统部署环境、安装调试流程和维护升级策略。最后,文章展望了病房呼叫系统的未来发展趋势,包括智能化、技术融合以及法规遵从与伦理考量,并
recommend-type

Selenium如何获取Shadow DOM下的元素属性?

在Selenium中,获取Shadow DOM下的元素属性通常涉及到两步:首先找到元素,然后访问它的属性。由于Shadow DOM元素默认是不可见的(对于非JavaScript开发者),所以我们需要用JavaScript脚本来获取其内容。 下面是一个示例,展示如何通过Selenium的`execute_script`函数获取Shadow DOM元素的属性: ```python from selenium.webdriver.common.by import By from selenium.webdriver.support.ui import WebDriverWait from sel
recommend-type

分享个人Vim与Git配置文件管理经验

资源摘要信息:"conffiles:我的vim和git配置文件" 在给定的文件信息中,我们可以梳理出一些关键知识点,这些知识点主要涉及到了Vim编辑器和Git版本控制系统,同时涉及到了Linux环境下的一些文件操作知识。 首先,文件标题提到了"conffiles",这通常是指配置文件(configuration files)的缩写。配置文件是软件运行时用于读取用户设置或其他运行参数的文件,它们允许软件按照用户的特定需求进行工作。在本例中,这些配置文件是与Vim编辑器和Git版本控制系统相关的。 Vim是一种流行的文本编辑器,是UNIX系统中vi编辑器的增强版本。Vim不仅支持代码编辑,还支持插件扩展、多种模式(命令模式、插入模式、视觉模式等)和高度可定制化。在这个上下文中,"我的vim"可能指的是使用者为Vim定制的一套配置文件,这些配置文件可能包含键位映射、颜色主题、插件设置、用户界面布局和其他个性化选项。 Git是一个版本控制系统,用于跟踪计算机文件的更改和协作。Git是分布式版本控制,这意味着每个开发者都有一个包含完整项目历史的仓库副本。Git常用于代码的版本控制管理,它允许用户回滚到之前的版本、合并来自不同贡献者的代码,并且有效地管理代码变更。在这个资源中,"git conffiles"可能表示与Git用户相关的配置文件,这可能包括用户凭证、代理设置、别名以及其他一些全局Git配置选项。 描述部分提到了使用者之前使用的编辑器是Vim,但现在转向了Emacs。尽管如此,该用户仍然保留了以前的Vim配置文件。接着,描述中提到了一个安装脚本命令"sh ./.vim/install.sh"。这是一个shell脚本,通常用于自动化安装或配置过程。在这里,这个脚本可能用于创建符号链接(symbolic links),将旧的Vim配置文件链接到当前使用的Emacs配置文件夹中,使用户能够继续使用他们熟悉且习惯的Vim配置。 标签"Vimscript"表明这是一个与Vim脚本相关的资源,Vim脚本是一种专门用于自定义和扩展Vim功能的编程语言。Vimscript可以用于编写宏、自定义函数、插件等。 最后,文件名称列表"conffiles-master"可能表明这个压缩包文件包含了一系列的主配置文件。在Git版本控制的术语中,"master"(现在通常称为"main")分支是项目仓库的默认分支。这暗示了这些配置文件可能是该用户项目的主配置文件,这些配置文件被包含在名为"conffiles-master"的压缩包中。 综上所述,这个资源可能是一个集合了Vim编辑器和Git版本控制系统的个人配置文件的压缩包,附带一个用于符号链接旧Vim配置的安装脚本,它能够帮助用户在转向其他工具时仍然能够使用之前的个性化设置。这个资源对于想要了解如何管理和迁移配置文件的用户具有一定的参考价值。