Mysql练习题,可对本章学习的内容进行巩固
dept.sql
部门表
SET NAMES utf8mb4; SET FOREIGN_KEY_CHECKS = 0; -- ---------------------------- -- Table structure for dept -- ---------------------------- DROP TABLE IF EXISTS `dept`; CREATE TABLE `dept` ( `DEPTNO` int(2) NOT NULL, `DNAME` varchar(14) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL, `LOC` varchar(13) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL, PRIMARY KEY (`DEPTNO`) USING BTREE ) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic; -- ---------------------------- -- Records of dept -- ---------------------------- INSERT INTO `dept` VALUES (10, 'ACCOUNTING', 'NEW YORK'); INSERT INTO `dept` VALUES (20, 'RESEARCH', 'DALLAS'); INSERT INTO `dept` VALUES (30, 'SALES', 'CHICAGO'); INSERT INTO `dept` VALUES (40, 'OPERATIONS', 'BOSTON'); SET FOREIGN_KEY_CHECKS = 1;emp.sql
员工表
SET NAMES utf8mb4; SET FOREIGN_KEY_CHECKS = 0; -- ---------------------------- -- Table structure for emp -- ---------------------------- DROP TABLE IF EXISTS `emp`; CREATE TABLE `emp` ( `EMPNO` int(4) NOT NULL, `ENAME` varchar(10) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL, `JOB` varchar(9) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL, `MGR` int(4) NULL DEFAULT NULL, `HIREDATE` date NULL DEFAULT NULL, `SAL` double(7, 2) NULL DEFAULT NULL, `COMM` double(7, 2) NULL DEFAULT NULL, `DEPTNO` int(2) NULL DEFAULT NULL, PRIMARY KEY (`EMPNO`) USING BTREE ) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic; -- ---------------------------- -- Records of emp -- ---------------------------- INSERT INTO `emp` VALUES (7369, 'SMITH', 'CLERK', 7902, '1980-12-17', 800.00, NULL, 20); INSERT INTO `emp` VALUES (7499, 'ALLEN', 'SALESMAN', 7698, '1981-02-20', 1600.00, 300.00, 30); INSERT INTO `emp` VALUES (7521, 'WARD', 'SALESMAN', 7698, '1981-02-22', 1250.00, 500.00, 30); INSERT INTO `emp` VALUES (7566, 'JONES', 'MANAGER', 7839, '1981-04-02', 2975.00, NULL, 20); INSERT INTO `emp` VALUES (7654, 'MARTIN', 'SALESMAN', 7698, '1981-09-28', 1250.00, 1400.00, 30); INSERT INTO `emp` VALUES (7698, 'BLAKE', 'MANAGER', 7839, '1981-05-01', 2850.00, NULL, 30); INSERT INTO `emp` VALUES (7782, 'CLARK', 'MANAGER', 7839, '1981-06-09', 2450.00, NULL, 10); INSERT INTO `emp` VALUES (7788, 'SCOTT', 'ANALYST', 7566, '1987-04-19', 3000.00, NULL, 20); INSERT INTO `emp` VALUES (7839, 'KING', 'PRESIDENT', NULL, '1981-11-17', 5000.00, NULL, 10); INSERT INTO `emp` VALUES (7844, 'TURNER', 'SALESMAN', 7698, '1981-09-08', 1500.00, 0.00, 30); INSERT INTO `emp` VALUES (7876, 'ADAMS', 'CLERK', 7788, '1987-05-23', 1100.00, NULL, 20); INSERT INTO `emp` VALUES (7900, 'JAMES', 'CLERK', 7698, '1981-12-03', 950.00, NULL, 30); INSERT INTO `emp` VALUES (7902, 'FORD', 'ANALYST', 7566, '1981-12-03', 3000.00, NULL, 20); INSERT INTO `emp` VALUES (7934, 'MILLER', 'CLERK', 7782, '1982-01-23', 1300.00, NULL, 10); SET FOREIGN_KEY_CHECKS = 1;salgrade.sql
等级划分表
SET NAMES utf8mb4; SET FOREIGN_KEY_CHECKS = 0; -- ---------------------------- -- Table structure for salgrade -- ---------------------------- DROP TABLE IF EXISTS `salgrade`; CREATE TABLE `salgrade` ( `GRADE` int(11) NULL DEFAULT NULL, `LOSAL` int(11) NULL DEFAULT NULL, `HISAL` int(11) NULL DEFAULT NULL ) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic; -- ---------------------------- -- Records of salgrade -- ---------------------------- INSERT INTO `salgrade` VALUES (1, 700, 1200); INSERT INTO `salgrade` VALUES (2, 1201, 1400); INSERT INTO `salgrade` VALUES (3, 1401, 2000); INSERT INTO `salgrade` VALUES (4, 2001, 3000); INSERT INTO `salgrade` VALUES (5, 3001, 9999); SET FOREIGN_KEY_CHECKS = 1;语法格式:select 字段1,字段2,字段3,… from 表名;
查询每个员工的工资
SELECT ename,sal from emp;给查询列起别名
SELECT ename,sal as '工资' from emp;注意:字符串要使用单引号括起来,尽量别使用双引号
条件查询需要用到where语句,where语句必须放到from语句后面。
语法格式如下
select 字段,字段... from 表名 where 条件;条件查询支持以下运算符
运算符说明=等于<>或 !=不等于<小于>大于<=小于等于>=大于等于between … and两个值之间,等同于 >= and <=is null为nulland并且or或者in包含,相当于多个or(not in 则是不在这个范围中)notnot 可以取非,主要用在 is 或 in 中likelike 称为模糊查询,支持%或下划线匹配查询工资为5000的员工姓名
select ename,sal from emp where sal = 5000;查询工资小于3000的员工姓名
select ename,sal from emp where sal < 3000;其余可参考之前的表格,这里我不做过多演示。
between and 在使用的时候必须是左小右大
select ename,sal from emp where sal between 2000 and 3000;between and 还可以使用在字符串方面(左为闭区间,右为开区间)
select ename from emp where ename between 'A' and 'C';在数据库当中NULL不是一个值,代表什么也没有,为空。空不是一个值,不能用等号判断,必须使用 is null 或 is not null 进行判断。
查询comm为null的数据
select ename,comm from emp where comm is null;查询comm为不为null的数据
select ename,comm from emp where comm is not null;in:sal值为3000和5000的数据
select ename,sal from emp where sal not in(3000,5000);not in:sal不在(3000,5000)这几个值中
搭配%使用
%代表一个或多个字符的通配符
(1)
select ename,sal from emp where ename like '%S%';ename like ‘%S%’; 名称中带有S的名字
(2)
select ename,sal from emp where ename like 'S%';查询名称中开始字符为S的数据
(3)
select ename,sal from emp where ename like '%S';插叙名称中最后一个字符为S的数据
搭配_使用
_代表仅仅一个字符的通配符
select ename,sal from emp where ename like 'KIN_';group by :按照某个字段或者某些字段进行分组 having:having是对分组之后的数据进行再次过滤。
select AVG(sal),deptno from emp group by deptno; select deptno from emp group by deptno having deptno >= 20;注意事项
GROUP BY后不可以接列的别名GROUP BY 后不能接数字GROUP BY 后不可以接select后没有的列名如果一个SELECT中使用了分组函数,任何不在分组函数中的列(表达式)必须要在GROUP BY中在使用数据库查询语句时,单表的查询有时候不能满足项目的业务需求,在项目开发过程中,有很多需求都是要涉及到多表的连接查询
连接查询分类
内连接 等值连接非等值连接自连接 外连接 左外连接(左连接)右外连接 (右连接) 全连接特点:条件是等量关系
查询每个员工的部门名称,要求显示员工名和部门名
select e.ename,d.dname from emp e join dept d on e.deptno = d.deptno;特点:连接条件是非等量关系
找出每个员工的工资等级,要求显示员工名、工资、工资等级
select e.ename,e.sal,s.grade from emp e join salgrade s on e.sal between s.losal and s.hisal;特点:一张表当成两张表。自己连接自己
找出每个员工的上级领导,要求显示员工名和对应的领导名称
select e.ename,m.ename from emp e left join emp m on e.mgr = m.empno;假设A和B表进行连接,使用外连接的话,AB两张表中有一张表是主表,一张表是副表,主要查询主表中的数据,捎带着查询副表,当副表中的数据没有和主表中的数据匹配上,副表自动模拟出NULL与之匹配。
外连接分类
左外连接(左连接):表示左边的这张表是主表。右外连接(右连接):表示右边的这张表是主表。 #基本语法 左表 left/right join 右表 on 左表.字段=右表.字段1、where后面嵌套子查询
select ename,sal from emp where sal > (select avg(sal) from emp);2、from后面嵌套子查询
列出各种工作的最低工资及从事此工作的雇员姓名
select e.ename,t.* from emp e join (select job,min(sal) as minsal from emp group by job) t on e.job=t.job and e.sal=t.minsal;3、select后面嵌套子查询
查询每个员工所在部门名称
select e.ename,d.dname, (select d.dname from dept d where e.deptno = d.deptno) as dname from emp e;觉得不错的小伙伴可以点赞关注和收藏哦!如有错误可以指出来。
Java学习路线目录索引