数据库单表,多表习题详解

本文详细讲解了数据库中的单表查询与多表查询技术,包括如何进行有效的单表操作以及如何通过JOIN等方法实现复杂的数据联查,帮助读者深入理解数据库查询原理。
摘要由CSDN通过智能技术生成

单表查询

一、单表查询
#素材: 表名: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 INTO worker (部门号, 职工号, 工作时间, 工资, 政治面貌, 姓名, 出生 日期) VALUES (101, 1001, ‘2015-5-4’, 3500.00, ‘群众’, ‘张三’, ‘1990-7-1’);
INSERT INTO worker (部门号, 职工号, 工作时间, 工资, 政治面貌, 姓名, 出生 日期) VALUES (101, 1002, ‘2017-2-6’, 3200.00, ‘团员’, ‘李四’, ‘1997-2-8’);
INSERT INTO worker (部门号, 职工号, 工作时间, 工资, 政治面貌, 姓名, 出生 日期) VALUES (102, 1003, ‘2011-1-4’, 8500.00, ‘党员’, ‘王亮’, ‘1983-6-8’);
INSERT INTO worker (部门号, 职工号, 工作时间, 工资, 政治面貌, 姓名, 出生 日期) VALUES (102, 1004, ‘2016-10-10’, 5500.00, ‘群众’, ‘赵六’, ‘1994-9-5’);
INSERT INTO worker (部门号, 职工号, 工作时间, 工资, 政治面貌, 姓名, 出生 日期) VALUES (102, 1005, ‘2014-4-1’, 4800.00, ‘党员’, ‘钱七’, ‘1992-12-30’);
INSERT INTO worker (部门号, 职工号, 工作时间, 工资, 政治面貌, 姓名, 出生 日期) VALUES (102, 1006, ‘2017-5-5’, 4500.00, ‘党员’, ‘孙八’, ‘1996-9-2’);
1、显示所有职工的基本信息。
mysql> select * from worker;
+-----------+-----------+--------------+---------+--------------+--------+--------------+
| 部门号    | 职工号    | 工作时间     | 工资    | 政治面貌     | 姓名   | 出生日期     |
+-----------+-----------+--------------+---------+--------------+--------+--------------+
|       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   |
+-----------+-----------+--------------+---------+--------------+--------+--------------+
6 rows in set (0.00 sec)

2、查询所有职工所属部门的部门号,不显示重复的部门号。
mysql> select distinct 部门号 from worker;
+-----------+
| 部门号    |
+-----------+
|       101 |
|       102 |
+-----------+
2 rows in set (0.01 sec)

3、求出所有职工的人数。
mysql> select count(职工号) from worker;
+------------------+
| count(职工号)    |
+------------------+
|                6 |
+------------------+
1 row in set (0.01 sec)

4、列出最高工和最低工资。
mysql> select max(工资), min(工资) from worker;
+-------------+-------------+
| max(工资)   | min(工资)   |
+-------------+-------------+
|     8500.00 |     3200.00 |
+-------------+-------------+
1 row in set (0.00 sec)

5、列出职工的平均工资和总工资。
mysql> select avg(工资), sum(工资) from worker;
+-------------+-------------+
| avg(工资)   | sum(工资)   |
+-------------+-------------+
| 5000.000000 |    30000.00 |
+-------------+-------------+
1 row in set (0.00 sec)

6、创建一个只有职工号、姓名和工作时间的新表,名为工作日期表。
mysql> create table workdate select 职工号,姓名,工作时间 from worker;
Query OK, 6 rows affected (0.19 sec)
Records: 6  Duplicates: 0  Warnings: 0

mysql> show tables;
+----------------+
| Tables_in_test |
+----------------+
| tb_student     |
| test           |
| test02         |
| test03         |
| test04         |
| test05         |
| workdate       |
| worker         |
+----------------+
8 rows in set (0.00 sec)

mysql> select * from workdate;
+-----------+--------+--------------+
| 职工号    | 姓名   | 工作时间     |
+-----------+--------+--------------+
|      1001 | 张三   | 2015-05-04   |
|      1002 | 李四   | 2017-02-06   |
|      1003 | 王亮   | 2011-01-04   |
|      1004 | 赵六   | 2016-10-10   |
|      1005 | 钱七   | 2014-04-01   |
|      1006 | 孙八   | 2017-05-05   |
+-----------+--------+--------------+
6 rows in set (0.00 sec)

7、显示所有职工的年龄。
mysql> select 姓名,(datediff(curdate(),出生日期) div 365) as 年龄 from worker;
+--------+--------+
| 姓名   | 年龄   |
+--------+--------+
| 张三   |     32 |
| 李四   |     25 |
| 王亮   |     39 |
| 赵六   |     28 |
| 钱七   |     29 |
| 孙八   |     26 |
+--------+--------+
6 rows in set (0.00 sec)

8、列出所有姓张的职工的职工号、姓名和出生日期。
select 职工号,姓名,.生日. from worker where 姓名 like '张%';

9、列出1999年以前出生的职工的姓名、参加工作日期。
select 姓名,工作时间 from worker where year(出生日期)<1999;
10、列出工资在3000-4000之间的所有职工姓名。
select 姓名 from worker where 工资 between 3000 and 4000;

11、列出所有陈姓和李姓的职工姓名。
select 姓名 from worker where 姓名 like '张%' or '李%';
select 姓名 from worker where 姓名 regexp '^(李|张)';

12、列出所有部门号为2和3的职工号、姓名、党员否。
select 职工号,姓名,政治面貌 from worker where 部门号 in (102,103);
13、将职工表worker中的职工按出生的先后顺序排序。
select * from worker order by 出生日期;

14、显示工资最高的前3名职工的职工号和姓名。
select 职工号,姓名 from worker order by 工资 desc limit 3;

15、求出各部门党员的人数。
select 部门号,count(1) from worker where 政治面貌='党员' group by 部门号;

16、统计各部门的工资和平均工资
select 部门号,sum(工资),avg(工资) from worker group by 部门号;

17、列出总人数大于4的部门号和总人数
select 部门号,count(1) from worker group by 部门号 having count(1)>4;

多表查询

多表查询
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);

3.查询student表的所有记录

 SELECT * FROM student;

4.查询student表的第2条到4条记录

SELECT * FROM student LIMIT 1,3; 

5.从student表查询所有学生的学号(id)、姓名(name)和院系(department)的信息

SELECT id,NAME,department FROM student;

6.从student表中查询计算机系和英语系的学生的信息

SELECT * FROM student WHERE department IN('计算机系','英语系');

7.从student表中查询年龄在18~35岁的学生信息

SELECT * FROM student WHERE YEAR(NOW())-birth BETWEEN 18 AND 35; 

8.查询每个院系有多少人

SELECT department,COUNT(department) counts FROM student GROUP BY department;

9.查询每个科目的最高分

SELECT c_name,MAX(grade) maxgrade FROM score GROUP BY c_name;

10.查询李四的考试科目(c_name)和考试成绩(grade)

SELECT c_name,grade FROM score WHERE stu_id =(SELECT id FROM student WHERE NAME='李四');

11.所有学生的信息和考试信息

SELECT * FROM student s,score sc WHERE s.`id`=sc.`stu_id`;
SELECT s.`id`,NAME,sex,birth,department,address,grade FROM student s,score sc WHERE s.`id`=sc.`stu_id`; 
12.计算每个学生的总成绩

SELECT NAME,SUM(grade) FROM student s,score sc WHERE s.`id`=sc.`stu_id` GROUP BY NAME;

13.计算每个考试科目的平均成绩
计算每个学生的平均成绩???

SELECT c_name,AVG(grade) FROM score GROUP BY c_name; 

14.查询计算机成绩低于95的学生信息

SELECT * FROM student WHERE id IN(SELECT stu_id FROM score WHERE c_name='计算机' AND grade<95)    

15.查询每个学科的平均成绩

SELECT c_name,AVG(grade) FROM score GROUP BY c_name;

16.将计算机考试成绩降序排列

SELECT c_name,grade FROM score WHERE c_name='计算机' ORDER BY grade DESC;

17.查询姓张或者姓王的同学的姓名、院系和考试科目及成绩

SELECT NAME,department,c_name,grade FROM student s,score sc WHERE s.`id`=sc.stu_id AND NAME LIKE '张%' OR NAME LIKE '王%'

18.查询都是湖南的学生的姓名、年龄、院系和考试科目及成绩

SELECT NAME,address,YEAR(NOW())-birth,department,c_name,grade FROM student INNER JOIN score ON student.`id`=score.`stu_id` WHERE address LIKE '%湖南%'

19.查询出每门课程都大于80分的学生姓名
类似于这个题目:查询所有成绩都及格的学生

SELECT st.`name`,MIN(s.grade) mi FROM student st
LEFT JOIN score s
ON s.`stu_id`=st.`id`
GROUP BY st.`name` HAVING mi>80;

20.查询平均分最高的科目名字

 SELECT c_name,MAX(avgs.av) FROM
(SELECT  AVG(grade) AS av,c_name FROM score GROUP BY c_name)
AS avgs

21.查询语文成绩比张三高的学生的信息
提示:
先查询张三的语文成绩;
再查询语文成绩成绩大于a的学生信息;

SELECT * FROM student st
LEFT JOIN score s
ON s.`stu_id`=st.`id`
WHERE s.c_name="中文" AND s.grade >
(SELECT s.grade FROM student st
LEFT JOIN score s
ON s.`stu_id`=st.`id`
WHERE s.c_name="中文" AND st.name="张三")
22.查询同时参加计算机和英语考试的学生的信息

SELECT * FROM student WHERE id IN (
SELECT stu_id FROM score WHERE c_name='计算机' AND stu_id IN (
SELECT stu_id FROM score WHERE c_name ='英语' ))
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值