请用sql语言写出下列要求。学校人力资源管理系统  实现学校部门信息,职务、职称和教职工信息管理;  实现教师的学籍经历管理;  实现教师的家庭关系管理;  实现教师的奖惩信息管理;  创建存储过程查询学校各部门各种职称的教职工数量;  创建触发器,当增加、删除教职工和修改教职工部门信息时自动修改相应部门的职工人数;  创建规则用于保证教职工的E-Mail的输入格式正确;  建立数据库相关表之间的参照完整性约束。

时间: 2024-03-13 10:47:29 浏览: 17
下面是针对学校人力资源管理系统的SQL语句: 1.创建部门信息表 ```sql CREATE TABLE department ( dep_id INT PRIMARY KEY, dep_name VARCHAR(50) NOT NULL, dep_manager VARCHAR(50) NOT NULL ); ``` 2.创建职务信息表 ```sql CREATE TABLE position ( pos_id INT PRIMARY KEY, pos_name VARCHAR(50) NOT NULL ); ``` 3.创建职称信息表 ```sql CREATE TABLE title ( title_id INT PRIMARY KEY, title_name VARCHAR(50) NOT NULL ); ``` 4.创建教职工信息表 ```sql CREATE TABLE teacher ( teacher_id INT PRIMARY KEY, teacher_name VARCHAR(50) NOT NULL, teacher_email VARCHAR(50) NOT NULL, teacher_dep_id INT NOT NULL, teacher_pos_id INT NOT NULL, teacher_title_id INT NOT NULL, FOREIGN KEY (teacher_dep_id) REFERENCES department(dep_id), FOREIGN KEY (teacher_pos_id) REFERENCES position(pos_id), FOREIGN KEY (teacher_title_id) REFERENCES title(title_id) ); ``` 5.创建学籍经历信息表 ```sql CREATE TABLE academic ( academic_id INT PRIMARY KEY, academic_name VARCHAR(50) NOT NULL, academic_start_date DATE NOT NULL, academic_end_date DATE NOT NULL, teacher_id INT NOT NULL, FOREIGN KEY (teacher_id) REFERENCES teacher(teacher_id) ); ``` 6.创建家庭关系信息表 ```sql CREATE TABLE family ( family_id INT PRIMARY KEY, family_name VARCHAR(50) NOT NULL, family_relation VARCHAR(50) NOT NULL, teacher_id INT NOT NULL, FOREIGN KEY (teacher_id) REFERENCES teacher(teacher_id) ); ``` 7.创建奖惩信息表 ```sql CREATE TABLE reward_punish ( rp_id INT PRIMARY KEY, rp_content VARCHAR(50) NOT NULL, rp_date DATE NOT NULL, teacher_id INT NOT NULL, FOREIGN KEY (teacher_id) REFERENCES teacher(teacher_id) ); ``` 8.创建存储过程查询学校各部门各种职称的教职工数量 ```sql CREATE PROCEDURE teacher_count() BEGIN SELECT dep_name, pos_name, title_name, COUNT(teacher_id) FROM teacher INNER JOIN department ON teacher_dep_id = dep_id INNER JOIN position ON teacher_pos_id = pos_id INNER JOIN title ON teacher_title_id = title_id GROUP BY dep_name, pos_name, title_name; END; ``` 9.创建触发器,当增加、删除教职工和修改教职工部门信息时自动修改相应部门的职工人数 ```sql CREATE TRIGGER teacher_count_update AFTER INSERT ON teacher FOR EACH ROW BEGIN UPDATE department SET dep_manager = dep_manager, COUNT = COUNT + 1 WHERE dep_id = NEW.teacher_dep_id; END; CREATE TRIGGER teacher_count_delete AFTER DELETE ON teacher FOR EACH ROW BEGIN UPDATE department SET dep_manager = dep_manager, COUNT = COUNT - 1 WHERE dep_id = OLD.teacher_dep_id; END; CREATE TRIGGER teacher_count_update AFTER UPDATE ON teacher FOR EACH ROW BEGIN UPDATE department SET dep_manager = dep_manager, COUNT = COUNT + 1 WHERE dep_id = NEW.teacher_dep_id; UPDATE department SET dep_manager = dep_manager, COUNT = COUNT - 1 WHERE dep_id = OLD.teacher_dep_id; END; ``` 10.创建规则用于保证教职工的E-Mail的输入格式正确 ```sql CREATE RULE email_rule AS ON INSERT TO teacher WHERE NOT (teacher_email LIKE '%@%.%') DO INSTEAD RAISE EXCEPTION 'Invalid email format'; ``` 11.建立数据库相关表之间的参照完整性约束 ```sql ALTER TABLE teacher ADD FOREIGN KEY (teacher_dep_id) REFERENCES department(dep_id) ON DELETE CASCADE; ALTER TABLE teacher ADD FOREIGN KEY (teacher_pos_id) REFERENCES position(pos_id) ON DELETE CASCADE; ALTER TABLE teacher ADD FOREIGN KEY (teacher_title_id) REFERENCES title(title_id) ON DELETE CASCADE; ALTER TABLE academic ADD FOREIGN KEY (teacher_id) REFERENCES teacher(teacher_id) ON DELETE CASCADE; ALTER TABLE family ADD FOREIGN KEY (teacher_id) REFERENCES teacher(teacher_id) ON DELETE CASCADE; ALTER TABLE reward_punish ADD FOREIGN KEY (teacher_id) REFERENCES teacher(teacher_id) ON DELETE CASCADE; ```

最新推荐

recommend-type

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

基于Java+sql教师信息管理系统课设报告,教师信息管理系统主要用于实现用户名的登陆,退出,教师信息的添加,查找, 删除,修改等功能。本系统的开发需要实现以下功能模块:对系统的图形界面化进行 操作,对sql...
recommend-type

论坛管理信息系统数据库系统设计

1设计内容及要求 1.1作者信息模块 用来管理作者信息,包括作者昵称、贴子编号、性别、年龄、职业、爱好等; 1.2贴子信息模块 用来管理贴子信息,包括贴子编号、发贴日期、时间、等级等; 1.3回复日期模块 用来管理...
recommend-type

JSP毕业生就业信息管理系统论文

第4章 毕业生就业系统实现 19 4.1 数据库连接 19 4.2 系统运行结果 20 4.2.2 注册界面 20 4.2.3 个人资料页面 22 4.2.4 学历信息页面 23 4.2.5 个人简历页面 23 4.2.6 首页页面 23 4.2.7 企业资料页面 24 4.2.8 职位...
recommend-type

vb.net人力资源信息管理系统

本文主要研究如何开发企业人力资源管理系统,解释了开发人力资源管理系统的必要性和重要性,采用Visual Basic.NET 和SQL Server 2000软件作为开发工具,通过对计算机硬件和软件解决方案的论证,对应用领域进行调查分析,...
recommend-type

SQL_数据库图书管理系统.docx

SQL_数据库图书管理系统,WORD文档较为规范,流程清楚,适合借鉴,0积分即可下载。
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

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

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

解释minorization-maximization (MM) algorithm,并给出matlab代码编写的例子

Minorization-maximization (MM) algorithm是一种常用的优化算法,用于求解非凸问题或含有约束的优化问题。该算法的基本思想是通过构造一个凸下界函数来逼近原问题,然后通过求解凸下界函数的最优解来逼近原问题的最优解。具体步骤如下: 1. 初始化参数 $\theta_0$,设 $k=0$; 2. 构造一个凸下界函数 $Q(\theta|\theta_k)$,使其满足 $Q(\theta_k|\theta_k)=f(\theta_k)$; 3. 求解 $Q(\theta|\theta_k)$ 的最优值 $\theta_{k+1}=\arg\min_\theta Q(
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。