- 部门表 dept:部门标号(DEPTNO),部门名称(DNAME),所在位置(LOC) - 雇员表 emp:员工标号(Empno),员工名称(Emname),员工工位(Job),经理(Mgr),雇佣日期(Hiredate),薪水(Sal),部门编号(Deptno) 写出 sql 语句: - 找出部门名称为 ACCOUNTING 的部门下的所有员工名称? - 找出部门名称为 SALES 的部门下每月需要发出的薪水总额? - 找出部门名称为 SALES 的部门的部门经理? - 找出部门名称为 RESEARCH 的部门下雇佣日期为 1980-12-17 的员工?

时间: 2023-05-23 20:06:58 浏览: 115
1. 找出部门名称为 ACCOUNTING 的部门下的所有员工名称: SELECT Emname FROM emp WHERE Deptno=(SELECT DEPTNO FROM dept WHERE DNAME='ACCOUNTING'); 2. 找出部门名称为 SALES 的部门下每月需要发出的薪水总额: SELECT SUM(Sal) FROM emp WHERE Deptno=(SELECT DEPTNO FROM dept WHERE DNAME='SALES'); 3. 找出部门名称为 SALES 的部门的部门经理: SELECT mgr FROM emp WHERE Deptno=(SELECT DEPTNO FROM dept WHERE DNAME='SALES') AND Job='MANAGER'; 4. 找出部门名称为 RESEARCH 的部门下雇佣日期为 1980-12-17 的员工: SELECT Emname FROM emp WHERE Deptno=(SELECT DEPTNO FROM dept WHERE DNAME='RESEARCH') AND Hiredate='1980-12-17';
相关问题

现有关系集合 emp(empno,ename.job,mgr,hiredate,sal,comm,deptno)dept(deptno,dname,loc)关系emp中各个属性的含义如下: empno(员工编号); ename(员工姓名);job(员工职位); mgr(员工的直接领导的员工编号);hiredate(员工入职日期); sal(员工工资); comm(员工补助);deptno(员工所在部门的部门编号)。 关系dept中各个属性的含义如下: deptno(部门编号); dname(部门名称); loc(部门所在城市)。请写出满足以下查询需求的关系代数表达式。 1.获得所有部门的员工人数,包括没有员工的部门。 2.获得scott的直接领导的姓名。 3.获得提供了工资在3000-4000之间对应的所有职位的部门,输出部门编号及部门名称。 4.获得工资比所在部门的平均工资高的员工的姓名,工资及所在部门的平均工资。

1. πdeptno, count(empno)(emp) ∪ πdeptno, 0(dept-πdeptno(emp)) 解释:在emp表中,对empno进行计数并按deptno进行分组,将结果与dept表中deptno列进行外连接,得到所有部门的员工人数,包括没有员工的部门。 2. πename(emp|σemp.mgr=scott.empno(emp)) 解释:在emp表中,选取mgr等于scott的empno的员工,然后再选择这些员工的ename列。 3. πdeptno, dname(dept|deptno in (πdeptno(σ3000≤sal and sal≤4000(emp)) ∩ πdeptno(emp))) 解释:首先在emp表中选取工资在3000-4000之间的员工,然后选择这些员工所在的部门编号,并与dept表中的deptno列进行交集运算,得到对应的部门编号,再根据这些部门编号选择dept表中的deptno和dname列。 4. πename, sal, avg(sal)(emp|sal > (select avg(sal) from emp as e where e.deptno = emp.deptno)) 解释:在emp表中,选择工资比所在部门平均工资高的员工,然后选择这些员工的ename和sal列,以及这些员工所在部门的平均工资。其中,平均工资的计算是在子查询中进行的,子查询中使用了emp表的别名e,且对e的deptno进行了限制,确保计算的是该员工所在部门的平均工资。

2.某数据库有3个基本表,部门表dept(部门编号deptno,部门名dname,地址loc),员工表emp(员工号empno,员工名ename, 雇佣日期hiredate,部门号deptno),考核表eval(员工号empno,年出勤数attnd,年考核成绩eval) 创建一个行级触发器 Trig_delete,如果在员工表中进行了删除员工的操作,则在考核表中应将该员工一起删除。

可以使用如下的 SQL 代码来创建这个行级触发器: ``` CREATE TRIGGER Trig_delete AFTER DELETE ON emp FOR EACH ROW BEGIN DELETE FROM eval WHERE empno = OLD.empno; END; ``` 解释一下以上代码的含义: - `CREATE TRIGGER Trig_delete`:创建一个名为 Trig_delete 的触发器。 - `AFTER DELETE ON emp`:指定该触发器在 emp 表中进行删除操作之后触发。 - `FOR EACH ROW`:指定该触发器对每一行进行操作。 - `BEGIN` 和 `END`:标记触发器的代码块。 - `DELETE FROM eval WHERE empno = OLD.empno;`:删除 eval 表中 empno 等于被删除员工的 empno 的行。`OLD` 是一个关键字,表示被删除的行。 当在员工表中进行了删除员工的操作时,该行级触发器 Trig_delete 就会自动触发,将考核表中该员工的记录一并删除。

相关推荐

emp员工表(empno员工号/ename员工姓名/job工作/mgr上级编号/hiredate受雇日期/sal薪金/comm佣金/deptno部门编号) dept部门表(deptno部门编号/dname部门名称/loc地点) 工资 = 薪金 + 佣金 问题: 1.列出至少有一个员工的所有部门 (3分) 2.列出薪金比“SMITH”多的所有员工。(3分) 3.列出所有员工的姓名及其直接上级的姓名。(3分) 4.列出受雇日期晚于其直接上级的所有员工。 (3分) 5.列出部门名称和这些部门的员工信息,同时列出那些没有员工的部门。(3分) 6.列出所有“CLERK”(办事员)的姓名及其部门名称。(3分) 7.列出最低薪金大于1500的各种工作。(3分) 8.列出在部门“SALES”(销售部)工作的员工的姓名,假定不知道销售部的部门编号。(4分) 9.列出薪金高于公司平均薪金的所有员工。(4分) 10.列出与“SCOTT”从事相同工作的所有员工。(4分) 11.列出薪金等于部门30中员工的薪金的所有员工的姓名和薪金。(4分) 12.列出薪金高于在部门30工作的所有员工的薪金的员工姓名和薪金。(4分) 13.列出在每个部门工作的员工数量、平均工资和平均服务期限。(4分) 14.列出所有员工的姓名、部门名称和工资。(5分) 15.列出所有部门的详细信息和部门人数。(5分) 16.列出各种工作的最低工资。(5分) 17.列出MANAGER(经理)的最低薪金。(5分) 18.列出所有员工的年工资,按年薪从低到高排序。(5分)

最新推荐

recommend-type

Oracle多表连接练习

练习题 1. 列出所有员工的姓名、部门名称和工资 ...3. 列出所有员工的年工资、所在部门名称,按年薪升序排序 Select e.ename,e.sal*12 income,d.dname From emp e,dept d Where e.deptno=d.deptno Order by income;
recommend-type

oracle数据库经典题目

数据库表空间分为系统表空间和非系统表空间两类,其中非系统表空间包括撤销表空间、临时表空间和用户表空间等。 SYSTEM表空间主要用于存储数据库的数据字典、PL/SQL程序的源代码和解释代码、数据库对象的定义。撤销...
recommend-type

智慧物流医药物流落地解决方案qytp.pptx

智慧物流医药物流落地解决方案qytp.pptx
recommend-type

JAVA物业管理系统设计与实现.zip

JAVA物业管理系统设计与实现
recommend-type

基于java的聊天系统的设计于实现.zip

基于java的聊天系统的设计于实现
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的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。