数据库SQL实战

编程入门 行业动态 更新时间:2024-10-07 20:29:19

数据库SQL<a href=https://www.elefans.com/category/jswz/34/1769775.html style=实战"/>

数据库SQL实战

1. 使用含有关键字exists查找未分配具体部门的员工的所有信息

1.1 题目描述

使用含有关键字exists查找未分配具体部门的员工的所有信息。
CREATE TABLE employees (
emp_no int(11) NOT NULL,
birth_date date NOT NULL,
first_name varchar(14) NOT NULL,
last_name varchar(16) NOT NULL,
gender char(1) NOT NULL,
hire_date date NOT NULL,
PRIMARY KEY (emp_no));
CREATE TABLE dept_emp (
emp_no int(11) NOT NULL,
dept_no char(4) NOT NULL,
from_date date NOT NULL,
to_date date NOT NULL,
PRIMARY KEY (emp_no,dept_no));
输出格式:

1.2 语句实现

select e.* 
from employees e
where not exists (select emp_no from dept_emp dwhere d.emp_no = e.emp_no);

2. 获取有奖金的员工相关信息

2.1 题目描述

获取有奖金的员工相关信息。
CREATE TABLE employees (
emp_no int(11) NOT NULL,
birth_date date NOT NULL,
first_name varchar(14) NOT NULL,
last_name varchar(16) NOT NULL,
gender char(1) NOT NULL,
hire_date date NOT NULL,
PRIMARY KEY (emp_no));
CREATE TABLE dept_emp (
emp_no int(11) NOT NULL,
dept_no char(4) NOT NULL,
from_date date NOT NULL,
to_date date NOT NULL,
PRIMARY KEY (emp_no,dept_no));
create table emp_bonus(
emp_no int not null,
received datetime not null,
btype smallint not null);
CREATE TABLE salaries (
emp_no int(11) NOT NULL,
salary int(11) NOT NULL,
from_date date NOT NULL,
to_date date NOT NULL, PRIMARY KEY (emp_no,from_date));
给出emp_no、first_name、last_name、奖金类型btype、对应的当前薪水情况salary以及奖金金额bonus。 bonus类型btype为1其奖金为薪水salary的10%,btype为2其奖金为薪水的20%,其他类型均为薪水的30%。 当前薪水表示to_date=‘9999-01-01’
输出格式:

2.2 语句实现

select eb.emp_no, e.first_name, e.last_name,eb.btype, s.salary, 
(case
when eb.btype = 1 then 0.1*s.salary
when eb.btype = 2 then 0.2*s.salary
else 0.3*s.salary
end) as bonus
from emp_bonus eb
inner join employees e on eb.emp_no = e.emp_no
inner join salaries s on eb.emp_no = s.emp_no
where s.to_date = '9999-01-01';

3. 统计salary的累计和running_total

3.1 题目描述

按照salary的累计和running_total,其中running_total为前N个当前( to_date = ‘9999-01-01’)员工的salary累计和,其他以此类推。 具体结果如下Demo展示。
CREATE TABLE salaries ( emp_no int(11) NOT NULL,
salary int(11) NOT NULL,
from_date date NOT NULL,
to_date date NOT NULL,
PRIMARY KEY (emp_no,from_date));
输出格式:

3.2 语句实现

select emp_no, salary, 
sum(salary) over (order by emp_no) as running_total
from salaries
where to_date = '9999-01-01';

4. 对于employees表中,给出奇数行的first_name

4.1 题目描述

对于employees表中,输出first_name排名(按first_name升序排序)为奇数的first_name
CREATE TABLE employees (
emp_no int(11) NOT NULL,
birth_date date NOT NULL,
first_name varchar(14) NOT NULL,
last_name varchar(16) NOT NULL,
gender char(1) NOT NULL,
hire_date date NOT NULL,
PRIMARY KEY (emp_no));
如,输入为:
INSERT INTO employees VALUES(10001,‘1953-09-02’,‘Georgi’,‘Facello’,‘M’,‘1986-06-26’);
INSERT INTO employees VALUES(10002,‘1964-06-02’,‘Bezalel’,‘Simmel’,‘F’,‘1985-11-21’);
INSERT INTO employees VALUES(10005,‘1955-01-21’,‘Kyoichi’,‘Maliniak’,‘M’,‘1989-09-12’);
INSERT INTO employees VALUES(10006,‘1953-04-20’,‘Anneke’,‘Preusig’,‘F’,‘1989-06-02’);
输出格式:

4.2 语句实现

/*
select f.first_name
from (select emp_no, first_name, row_number() over (order by first_name) as row_numfrom employees) as f
where row_num % 2 = 1
order by emp_no;
*/
select e1.first_name
from employees e1
where (select count(*) from employees e2where e1.first_name >= e2.first_name) % 2 = 1;

更多推荐

数据库SQL实战

本文发布于:2024-02-13 18:52:55,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1760548.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:实战   数据库   SQL

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!