数据库的单表和多表查询
一、单表查询
素材: 表名:worker-- 表中字段均为中文,比如 部门号 工资 职工号 参加工作 等
CREATE TABLE
worker
(
部门号
int(11) NOT NULL,
职工号
int(11) NOT NULL,
工作时间
date NOT NULL,
工资
float(8,2) NOT NULL,
政治面貌
varchar(10) NOT NULL DEFAULT ‘群众’,
姓名
varchar(20) NOT NULL,
出生日期
date NOT NULL,
PRIMARY KEY (职工号
)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC;
INSERT INTOworker
(部门号
,职工号
,工作时间
,工资
,政治面貌
,姓名
,出生 日期
) VALUES (101, 1001, ‘2015-5-4’, 3500.00, ‘群众’, ‘张三’, ‘1990-7-1’);
INSERT INTOworker
(部门号
,职工号
,工作时间
,工资
,政治面貌
,姓名
,出生 日期
) VALUES (101, 1002, ‘2017-2-6’, 3200.00, ‘团员’, ‘李四’, ‘1997-2-8’);
INSERT INTOworker
(部门号
,职工号
,工作时间
,工资
,政治面貌
,姓名
,出生 日期
) VALUES (102, 1003, ‘2011-1-4’, 8500.00, ‘党员’, ‘王亮’, ‘1983-6-8’);
INSERT INTOworker
(部门号
,职工号
,工作时间
,工资
,政治面貌
,姓名
,出生 日期
) VALUES (102, 1004, ‘2016-10-10’, 5500.00, ‘群众’, ‘赵六’, ‘1994-9-5’);
INSERT INTOworker
(部门号
,职工号
,工作时间
,工资
,政治面貌
,姓名
,出生 日期
) VALUES (102, 1005, ‘2014-4-1’, 4800.00, ‘党员’, ‘钱七’, ‘1992-12-30’);
INSERT INTOworker
(部门号
,职工号
,工作时间
,工资
,政治面貌
,姓名
,出生 日期
) VALUES (102, 1006, ‘2017-5-5’, 4500.00, ‘党员’, ‘孙八’, ‘1996-9-2’);
1、显示所有职工的基本信息。
2、查询所有职工所属部门的部门号,不显示重复的部门号。
3、求出所有职工的人数。
4、列出最高工和最低工资。
5、列出职工的平均工资和总工资。
6、创建一个只有职工号、姓名和参加工作的新表,名为工作日期表。
7、显示所有女职工的年龄。
8、列出所有姓刘的职工的职工号、姓名和出生日期。
9、列出1960年以前出生的职工的姓名、参加工作日期。
10、列出工资在1000-2000之间的所有职工姓名。
11、列出所有陈姓和李姓的职工姓名。
12、列出所有部门号为2和3的职工号、姓名、党员否。
13、将职工表worker中的职工按出生的先后顺序排序。
14、显示工资最高的前3名职工的职工号和姓名。
15、求出各部门党员的人数。
16、统计各部门的工资和平均工资
17、列出总人数大于4的部门号和总人数。
#创建表结构 注意中文用
(反引号)
mysql8.0 [chap04]>create table worker1(部门号
int not null,职工号
int not null,工作时间
date not null,工资
float(8,2) not null,政治面貌
char(10) not nulldefault ‘群众’,姓名
char(30) not null,出生日期
date not null);
#查看mysql结构
mysql8.0 [chap04]>desc worker1;
±-------------±-----------±-----±----±--------±------+
| Field | Type | Null | Key | Default | Extra |
±-------------±-----------±-----±----±--------±------+
| 部门号 | int | NO | | NULL | |
| 职工号 | int | NO | | NULL | |
| 工作时间 | date | NO | | NULL | |
| 工资 | float(8,2) | NO | | NULL | |
| 政治面貌 | char(10) | NO | | 群众 | |
| 姓名 | char(30) | NO | | NULL | |
| 出生日期 | date | NO | | NULL | |
#插入内容
mysql8.0 [chap04]>insert into worker1 values(101,1001,‘2015-5-4’,3500.00,‘群众’,’
张三’,‘1990-7-1’),(101,1002,‘2017-2-6’,3200.00,‘团员’,‘李四’,‘1997-2-8’),(102,1003,‘2011-1-4’,8500.00,‘党员’,‘王亮’,‘1983-6-8’),(102,1004,‘2016-10-10’,5500.00,‘群众’,‘赵六’,‘1994-9-5’),(102,1005,‘2014-4-1’,4800.00,‘党员’,‘钱七’,‘1992-12-30’),(102,1006,‘2017-5-5’,4500.00,‘党员’,‘孙八’,‘1996-9-2’);
#查看表内容
mysql8.0 [chap04]>select * from worker1;
±----------±----------±-------------±--------±-------------±-------±-------------+
| 部门号 | 职工号 | 工作时间 | 工资 | 政治面貌 | 姓名 | 出生日期 |
±----------±----------±-------------±--------±-------------±-------±-------------+
| 101 | 1001 | 2015-05-04 | 3500.00 | 群众 | 张三 | 1990-07-01 |
| 101 | 1002 | 2017-02-06 | 3200.00 | 团员 | 李四 | 1997-02-08 |
| 102 | 1003 | 2011-01-04 | 8500.00 | 党员 | 王亮 | 1983-06-08 |
| 102 | 1004 | 2016-10-10 | 5500.00 | 群众 | 赵六 | 1994-09-05 |
| 102 | 1005 | 2014-04-01 | 4800.00 | 党员 | 钱七 | 1992-12-30 |
| 102 | 1006 | 2017-05-05 | 4500.00 | 党员 | 孙八 | 1996-09-02
1、显示所有职工的基本信息。
mysql8.0 [chap04]>select * from worker1;
±----------±----------±-------------±--------±-------------±-------±-------------+
| 部门号 | 职工号 | 工作时间 | 工资 | 政治面貌 | 姓名 | 出生日期 |
±----------±----------±-------------±--------±-------------±-------±-------------+
| 101 | 1001 | 2015-05-04 | 3500.00 | 群众 | 张三 | 1990-07-01 |
| 101 | 1002 | 2017-02-06 | 3200.00 | 团员 | 李四 | 1997-02-08 |
| 102 | 1003 | 2011-01-04 | 8500.00 | 党员 | 王亮 | 1983-06-08 |
| 102 | 1004 | 2016-10-10 | 5500.00 | 群众 | 赵六 | 1994-09-05 |
| 102 | 1005 | 2014-04-01 | 4800.00 | 党员 | 钱七 | 1992-12-30 |
| 102 | 1006 | 2017-05-05 | 4500.00 | 党员 | 孙八 | 1996-09-02 |
2、查询所有职工所属部门的部门号,不显示重复的部门号。
mysql8.0 [chap04]>select distinct
部门号
from worker1;
±----------+
| 部门号 |
±----------+
| 101 |
| 102 |
3、求出所有职工的人数。
mysql8.0 [chap04]>select count() from worker1;
±---------+
| count() |
±---------+
| 6 |
4、列出最高工和最低工资。
mysql8.0 [chap04]>select max(
工资
) as ‘最高’,min(工资
) as ‘最低’ from worker1;
±--------±--------+
| 最高 | 最低 |
±--------±--------+
| 8500.00 | 3200.00 |
5、列出职工的平均工资和总工资。
mysql8.0 [chap04]>select
部门号
,avg(工资
),sum(工资
) from worker1 group by部门号
;
±----------±--------------±--------------+
| 部门号 | avg(工资
) | sum(工资
) |
±----------±--------------±--------------+
| 101 | 3350.000000 | 6700.00 |
| 102 | 5825.000000 | 23300.00 |
6、创建一个只有职工号、姓名和参加工作的新表,名为工作日期表。
mysql8.0 [chap04]>create table
工作日期表
select职工号
,姓名
,部门号
from worker1;
#查看
mysql8.0 [chap04]>select * from工作日期表
;
±----------±-------±----------+
| 职工号 | 姓名 | 部门号 |
±----------±-------±----------+
| 1001 | 张三 | 101 |
| 1002 | 李四 | 101 |
| 1003 | 王亮 | 102 |
| 1004 | 赵六 | 102 |
| 1005 | 钱七 | 102 |
| 1006 | 孙八 | 102 |
7、显示所有女职工的年龄。
mysql8.0 [chap04]>select ‘2023’-year(
出生日期
) from worker1 where性别
=“女”;
±----------------------------+
| ‘2023’-year(出生日期
) |
±----------------------------+
| 33 |
| 29 |
| 27 |
8、列出所有姓刘的职工的职工号、姓名和出生日期。
mysql8.0 [chap04]>select
职工号
,姓名
,出生日期
from worker1 where姓名
like"刘%";
Empty set (0.00 sec)
9、列出1960年以前出生的职工的姓名、参加工作日期。
mysql8.0 [chap04]>select
姓名
,工作时间
from worker1 where出生日期
<=“1960-01-01”;
Empty set (0.00 sec)
10、列出工资在1000-2000之间的所有职工姓名。
mysql8.0 [chap04]>select
姓名
from worker1 where工资
between 3000 and 6000;
±-------+
| 姓名 |
±-------+
| 张三 |
| 李四 |
| 赵六 |
| 钱七 |
| 孙八 |
11、列出所有陈姓和李姓的职工姓名。
mysql8.0 [chap04]>select
姓名
from worker1 where姓名
like ‘李%’ or姓名
like ‘陈%’;
±-------+
| 姓名 |
±-------+
| 李四 |
12、列出所有部门号为2和3的职工号、姓名、党员否。
mysql8.0 [chap04]>select
职工号
,政治面貌
,姓名
from worker1 where部门号
=102 or部门号
=103;
±----------±-------------±-------+
| 职工号 | 政治面貌 | 姓名 |
±----------±-------------±-------+
| 1003 | 党员 | 王亮 |
| 1004 | 群众 | 赵六 |
| 1005 | 党员 | 钱七 |
| 1006 | 党员 | 孙八 |
13、将职工表worker中的职工按出生的先后顺序排序。
mysql8.0 [chap04]>select
出生日期
from worker1 order by出生日期
;
±-------------+
| 出生日期 |
±-------------+
| 1983-06-08 |
| 1990-07-01 |
| 1992-12-30 |
| 1994-09-05 |
| 1996-09-02 |
| 1997-02-08 |
14、显示工资最高的前3名职工的职工号和姓名。
mysql8.0 [chap04]>select
职工号
,姓名
,工资
from worker1 order by工资
desc limit 3;
±----------±-------±--------+
| 职工号 | 姓名 | 工资 |
±----------±-------±--------+
| 1003 | 王亮 | 8500.00 |
| 1004 | 赵六 | 5500.00 |
| 1005 | 钱七 | 4800.00 |
15、求出各部门党员的人数。
mysql8.0 [chap04]>select 部门号,count(*) as 党员总数 from worker1 where 政治面貌=‘党员’ group by 部门号;
±----------±-------------+
| 部门号 | 党员总数 |
±----------±-------------+
| 102 | 3 |
16、统计各部门的工资和平均工资
mysql8.0 [chap04]>select 部门号,avg(工资),group_concat(工资) from worker1 group by 部门号;
±----------±------------±--------------------------------+
| 部门号 | avg(工资) | group_concat(工资) |
±----------±------------±--------------------------------+
| 101 | 3350.000000 | 3500.00,3200.00 |
| 102 | 5825.000000 | 8500.00,5500.00,4800.00,4500.00 |
17、列出总人数大于4的部门号和总人数。
mysql8.0 [chap04]>select 部门号,count(部门号) from worker1 group by 部门号 having count(部门号)>=4 ;
±----------±-----------------+
| 部门号 | count(部门号) |
±----------±-----------------+
| 102 | 4 |
±----------±-----------------+
1 row in set (0.00 sec)
二、多表查询
1.创建student和score表
CREATE TABLE student (
id INT(10) NOT NULL UNIQUE PRIMARY KEY ,
name VARCHAR(20) NOT NULL ,
sex VARCHAR(4) ,
birth YEAR,
department VARCHAR(20) ,
address VARCHAR(50)
);
创建score表。SQL代码如下:
CREATE TABLE score (
id INT(10) NOT NULL UNIQUE PRIMARY KEY AUTO_INCREMENT ,
stu_id INT(10) NOT NULL ,
c_name VARCHAR(20) ,
grade INT(10)
);
2.为student表和score表增加记录
向student表插入记录的INSERT语句如下:
INSERT INTO student VALUES( 901,‘张老大’, ‘男’,1985,‘计算机系’, ‘北京市海淀区’);
INSERT INTO student VALUES( 902,‘张老二’, ‘男’,1986,‘中文系’, ‘北京市昌平区’);
INSERT INTO student VALUES( 903,‘张三’, ‘女’,1990,‘中文系’, ‘湖南省永州市’);
INSERT INTO student VALUES( 904,‘李四’, ‘男’,1990,‘英语系’, ‘辽宁省阜新市’);
INSERT INTO student VALUES( 905,‘王五’, ‘女’,1991,‘英语系’, ‘福建省厦门市’);
INSERT INTO student VALUES( 906,‘王六’, ‘男’,1988,‘计算机系’, ‘湖南省衡阳市’);
向score表插入记录的INSERT语句如下:
INSERT INTO score VALUES(NULL,901, ‘计算机’,98);
INSERT INTO score VALUES(NULL,901, ‘英语’, 80);
INSERT INTO score VALUES(NULL,902, ‘计算机’,65);
INSERT INTO score VALUES(NULL,902, ‘中文’,88);
INSERT INTO score VALUES(NULL,903, ‘中文’,95);
INSERT INTO score VALUES(NULL,904, ‘计算机’,70);
INSERT INTO score VALUES(NULL,904, ‘英语’,92);
INSERT INTO score VALUES(NULL,905, ‘英语’,94);
INSERT INTO score VALUES(NULL,906, ‘计算机’,90);
INSERT INTO score VALUES(NULL,906, ‘英语’,85);
1.查询student表的所有记录
2.查询student表的第2条到4条记录
3.从student表查询所有学生的学号(id)、姓名(name)和院系(department)的信息
4.从student表中查询计算机系和英语系的学生的信息
5.从student表中查询年龄18~22岁的学生信息
6.从student表中查询每个院系有多少人
7.从score表中查询每个科目的最高分
8.查询李四的考试科目(c_name)和考试成绩(grade)
9.用连接的方式查询所有学生的信息和考试信息
10.计算每个学生的总成绩
11.计算每个考试科目的平均成绩
12.查询计算机成绩低于95的学生信息
13.查询同时参加计算机和英语考试的学生的信息
14.将计算机考试成绩按从高到低进行排序
15.从student表和score表中查询出学生的学号,然后合并查询结果
16.查询姓张或者姓王的同学的姓名、院系和考试科目及成绩
17.查询都是湖南的学生的姓名、年龄、院系和考试科目及成绩
1.查询student表的所有记录
select * from student;
2.查询student表的第2条到4条记录
select * from student limit 1,4;
3.从student表查询所有学生的学号(id)、姓名(name)和院系(department)的信息
select id,name,department from student;
4.从student表中查询计算机系和英语系的学生的信息
select * from student where department=“计算机系” or department=“英语系”;
5.从student表中查询年龄18~22岁的学生信息
select ‘2023’-birth as “年龄” from student where “年龄” between 18 and 22 ;
6.从student表中查询每个院系有多少人
select department,count(*) from student group by department ;
7.从score表中查询每个科目的最高分
select c_name,max(grade) from score group by c_name;
8.查询李四的考试科目(c_name)和考试成绩(grade)
mysql8.0 [chap04]>select c_name,grade from student s inner join score g on s.id=g.stu_id where s.name like “李四”;
9.用连接的方式查询所有学生的信息和考试信息
select * from student s inner join score g on s.id=g.stu_id;
10.计算每个学生的总成绩
mysql8.0 [chap04]>select name,stu_id,sum(s.grade) from score as s inner JOIN student as st ON s.stu_id = st.id group by(stu_id);
±----------±-------±-------------+
| name | stu_id | sum(s.grade) |
±----------±-------±-------------+
| 张老大 | 901 | 178 |
| 张老二 | 902 | 153 |
| 张三 | 903 | 95 |
| 李四 | 904 | 162 |
| 王五 | 905 | 94 |
| 王六 | 906 | 175 |
11.计算每个考试科目的平均成绩
mysql8.0 [chap04]>select c_name,avg(grade) from score group by(c_name);
±----------±-----------+
| c_name | avg(grade) |
±----------±-----------+
| 计算机 | 80.7500 |
| 英语 | 87.7500 |
| 中文 | 91.5000 |
12.查询计算机成绩低于95的学生信息
mysql8.0 [chap04]>select s.* from student s inner join score g on s.id=g.stu_id where g.grade<95;
±----±----------±-----±------±-------------±-------------------+
| id | name | sex | birth | department | address |
±----±----------±-----±------±-------------±-------------------+
| 901 | 张老大 | 男 | 1985 | 计算机系 | 北京市海淀区 |
| 902 | 张老二 | 男 | 1986 | 中文系 | 北京市昌平区 |
| 902 | 张老二 | 男 | 1986 | 中文系 | 北京市昌平区 |
| 904 | 李四 | 男 | 1990 | 英语系 | 辽宁省阜新市 |
| 904 | 李四 | 男 | 1990 | 英语系 | 辽宁省阜新市 |
| 905 | 王五 | 女 | 1991 | 英语系 | 福建省厦门市 |
| 906 | 王六 | 男 | 1988 | 计算机系 | 湖南省衡阳市 |
| 906 | 王六 | 男 | 1988 | 计算机系 | 湖南省衡阳市 |
13.查询同时参加计算机和英语考试的学生的信息
select stu_id,group_concat(c_name) from score group by stu_id having group_concat(c_name)=“计算机,英语”;
14.将计算机考试成绩按从高到低进行排序
mysql8.0 [chap04]>select * from score where c_name=‘计算机’ order by(grade) desc;
±—±-------±----------±------+
| id | stu_id | c_name | grade |
±—±-------±----------±------+
| 1 | 901 | 计算机 | 98 |
| 9 | 906 | 计算机 | 90 |
| 6 | 904 | 计算机 | 70 |
| 3 | 902 | 计算机 | 65 |
————————————————
15.从student表和score表中查询出学生的学号,然后合并查询结果
mysql8.0 [chap04]>select group_concat(s.stu_id) from score as s INNER JOIN student as st ON s.stu_id = st.id;
±----------------------------------------+
| group_concat(s.stu_id) |
±----------------------------------------+
| 901,901,902,902,903,904,904,905,906,906 |
16.查询姓张或者姓王的同学的姓名、院系和考试科目及成绩
mysql8.0 [chap04]>select s.name,s.department,g.c_name,g.grade from student s inner join score g on s.id=g.stu_id where name like “张%” or name like “王%”;
±----------±-------------±----------±------+
| name | department | c_name | grade |
±----------±-------------±----------±------+
| 张老大 | 计算机系 | 计算机 | 98 |
| 张老大 | 计算机系 | 英语 | 80 |
| 张老二 | 中文系 | 计算机 | 65 |
| 张老二 | 中文系 | 中文 | 88 |
| 张三 | 中文系 | 中文 | 95 |
| 王五 | 英语系 | 英语 | 94 |
| 王六 | 计算机系 | 计算机 | 90 |
| 王六 | 计算机系 | 英语 | 85 |
±----------±-------------±----------±------+
8 rows in set (0.01 sec)
17.查询都是湖南的学生的姓名、年龄、院系和考试科目及成绩
mysql8.0 [chap04]>select s.name,s.department,g.c_name,g.grade,‘2023’-s.birth as 年龄 from student s inner join score g on s.id=g.stu_id where address like “湖南%”;
±-------±-------------±----------±------±-------+
| name | department | c_name | grade | 年龄 |
±-------±-------------±----------±------±-------+
| 张三 | 中文系 | 中文 | 95 | 33 |
| 王六 | 计算机系 | 计算机 | 90 | 35 |
| 王六 | 计算机系 | 英语 | 85 | 35 |
±-------±-------------±----------±------±-------+
3 rows in set (0.00 sec)