MySQL 查询练习

创建数据库和表

CREATE DATABASE mydb8_worker;
USE mydb8_worker;

CREATE TABLE t_worker (
    department_id INT NOT NULL COMMENT '部门号',
    worker_id INT PRIMARY KEY NOT NULL COMMENT '职工号',
    worker_date DATE NOT NULL COMMENT '工作时间',
    wages FLOAT(8,2) NOT NULL COMMENT '工资',
    politics VARCHAR(10) NOT NULL DEFAULT '群众' COMMENT '政治面貌',
    name VARCHAR(20) NOT NULL COMMENT '姓名',
    borth_date DATE NOT NULL COMMENT '出生日期'
);

插入数据

INSERT INTO t_worker VALUES (101,1001,'2015-5-4',7500.00,'群众','张春燕','1990-7-1');
INSERT INTO t_worker VALUES (101,1002,'2019-2-6',5200.00,'团员','李名博','1997-2-8');
INSERT INTO t_worker VALUES (102,1003,'2008-1-4',10500.00,'党员','王博涵','1983-6-8');
INSERT INTO t_worker VALUES (102,1004,'2016-10-10',5500.00,'群众','赵小军','1994-9-5');
INSERT INTO t_worker VALUES (102,1005,'2014-4-1',8800.00,'党员','钱有财','1992-12-30');
INSERT INTO t_worker VALUES (103,1006,'2019-5-5',5500.00,'党员','孙菲菲','1996-9-2');

完成查询

(1)、显示所有职工的基本信息。
(2)、查询所有职工所属部门的部门号,不显示重复的部门号。
(3)、求出所有职工的人数。
(4)、列出最高工和最低工资。
(5)、列出职工的平均工资和总工资。
(6)、创建一个只有职工号、姓名和参加工作的新表,名为工作日期表。
(7)、显示所有党员的年龄。
(8)、列出工资在4000-8000之间的所有职工姓名
(9)、列出所有孙姓和李姓的职工姓名。
(10)、列出所有部门号为102和103且不是党员的职工号、姓名。
(11)、将职工表t_worker中的职工按出生的先后顺序排序。
(12)、显示工资最高的前3名职工的职工号和姓名。
(13)、求出各部门党员的人数。
(14)、统计各部门的工资和平均工资并保留2位小数

(15)、列出总人数大于等于3的部门号和总人数。

(1)、显示所有职工的基本信息。

MySQL root@(none):mydb8_worker> select * from t_worker;
+---------------+-----------+-------------+---------+----------+--------+------------+
| department_id | worker_id | worker_date | wages   | politics | name   | borth_date |
+---------------+-----------+-------------+---------+----------+--------+------------+
| 101           | 1001      | 2015-05-04  |  7500.0 | 群众     | 张春燕 | 1990-07-01 |
| 101           | 1002      | 2019-02-06  |  5200.0 | 团员     | 李名博 | 1997-02-08 |
| 102           | 1003      | 2008-01-04  | 10500.0 | 党员     | 王博涵 | 1983-06-08 |
| 102           | 1004      | 2016-10-10  |  5500.0 | 群众     | 赵小军 | 1994-09-05 |
| 102           | 1005      | 2014-04-01  |  8800.0 | 党员     | 钱有财 | 1992-12-30 |
| 103           | 1006      | 2019-05-05  |  5500.0 | 党员     | 孙菲菲 | 1996-09-02 |
+---------------+-----------+-------------+---------+----------+--------+------------+

(2)、查询所有职工所属部门的部门号,不显示重复的部门号。
 

MySQL root@(none):mydb8_worker> select distinct department_id from t_worker;
+---------------+
| department_id |
+---------------+
| 101           |
| 102           |
| 103           |
+---------------+

(3)、求出所有职工的人数。
 

MySQL root@(none):mydb8_worker> select count(1) from t_worker;
+----------+
| count(1) |
+----------+
| 6        |
+----------+

(4)、列出最高工和最低工资。
 

MySQL root@(none):mydb8_worker> select max(wages),min(wages) from t_worker;
+------------+------------+
| max(wages) | min(wages) |
+------------+------------+
| 10500.0    | 5200.0     |
+------------+------------+

(5)、列出职工的平均工资和总工资。
 

MySQL root@(none):mydb8_worker> select sum(wages),avg(wages) from t_worker;
+------------+-------------+
| sum(wages) | avg(wages)  |
+------------+-------------+
| 43000.0    | 7166.666667 |
+------------+-------------+

(6)、创建一个只有职工号、姓名和参加工作的新表,名为工作日期表。
 

MySQL root@(none):mydb8_worker> CREATE TABLE work_log(worker_id int,name varchar(50),work_date date);
Query OK, 0 rows affected
Time: 0.013s

MySQL root@(none):mydb8_worker> desc work_log;
+-----------+-------------+------+-----+---------+-------+
| Field     | Type        | Null | Key | Default | Extra |
+-----------+-------------+------+-----+---------+-------+
| worker_id | int         | YES  |     | <null>  |       |
| name      | varchar(50) | YES  |     | <null>  |       |
| work_date | date        | YES  |     | <null>  |       |
+-----------+-------------+------+-----+---------+-------+

(7)、显示所有党员的年龄。
 

MySQL root@(none):mydb8_worker> select year(now()) - year(borth_date) from t_worker;
+--------------------------------+
| year(now()) - year(borth_date) |
+--------------------------------+
| 34                             |
| 27                             |
| 41                             |
| 30                             |
| 32                             |
| 28                             |
+--------------------------------+

(8)、列出工资在4000-8000之间的所有职工姓名
 

select name from t_worker where wages>=4000 and wages<=8000;
+--------+
| name   |
+--------+
| 张春燕 |
| 李名博 |
| 赵小军 |
| 孙菲菲 |
+--------+

(9)、列出所有孙姓和李姓的职工姓名。
 

SELECT name FROM t_worker WHERE name LIKE '孙%' or name LIKE '李%';
+--------+
| name   |
+--------+
| 李名博 |
| 孙菲菲 |
+--------+

(10)、列出所有部门号为102和103且不是党员的职工号、姓名。
 

select worker_id,name from t_worker 
where department_id in 
(select department_id from t_worker 
where department_id=102 or department_id=103) 
and politics != '党员';
+-----------+--------+
| worker_id | name   |
+-----------+--------+
| 1004      | 赵小军 |
+-----------+--------+

(11)、将职工表t_worker中的职工按出生的先后顺序排序。
 

select * from t_worker 
order by borth_date 
in (select borth_date from t_worker);
+---------------+-----------+-------------+---------+----------+--------+------------+
| department_id | worker_id | worker_date | wages   | politics | name   | borth_date |
+---------------+-----------+-------------+---------+----------+--------+------------+
| 101           | 1001      | 2015-05-04  |  7500.0 | 群众     | 张春燕 | 1990-07-01 |
| 101           | 1002      | 2019-02-06  |  5200.0 | 团员     | 李名博 | 1997-02-08 |
| 102           | 1003      | 2008-01-04  | 10500.0 | 党员     | 王博涵 | 1983-06-08 |
| 102           | 1004      | 2016-10-10  |  5500.0 | 群众     | 赵小军 | 1994-09-05 |
| 102           | 1005      | 2014-04-01  |  8800.0 | 党员     | 钱有财 | 1992-12-30 |
| 103           | 1006      | 2019-05-05  |  5500.0 | 党员     | 孙菲菲 | 1996-09-02 |
+---------------+-----------+-------------+---------+----------+--------+------------+

(12)、显示工资最高的前3名职工的职工号和姓名。

select worker_id,name,wages from t_worker order by wages desc limit 3;
+-----------+--------+---------+
| worker_id | name   | wages   |
+-----------+--------+---------+
| 1003      | 王博涵 | 10500.0 |
| 1005      | 钱有财 |  8800.0 |
| 1001      | 张春燕 |  7500.0 |
+-----------+--------+---------+

(13)、求出各部门党员的人数。

select department_id,count(1) from t_worker where politics ='党员' group 
                             -> by department_id;
+---------------+----------+
| department_id | count(1) |
+---------------+----------+
| 102           | 2        |
| 103           | 1        |
+---------------+----------+

(14)、统计各部门的工资和平均工资并保留2位小数

select department_id,round(avg(wages),2) 
from t_worker
group by department_id;
+---------------+---------------------+
| department_id | round(avg(wages),2) |
+---------------+---------------------+
| 101           | 6350.0              |
| 102           | 8266.67             |
| 103           | 5500.0              |
+---------------+---------------------+

(15)、列出总人数大于等于3的部门号和总人数。

select department_id,count(1) 人数 
from t_worker 
group by department_id having count(1)>=3 ;
+---------------+------+
| department_id | 人数 |
+---------------+------+
| 102           | 3    |
+---------------+------+

  • 8
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

妍妍的宝贝

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值