Mysql查询详解(条件查询、子查询、模糊查询、连接查询。。。)


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 为null
and 并且
or 或者
in 包含,相当于多个or(not in 则是不在这个范围中)
not not 可以取非,主要用在 is 或 in 中
like like 称为模糊查询,支持%或下划线匹配

==查询工资为5000的员工姓名==

select 
    ename,sal 
from 
    emp 
where 
    sal = 5000;

在这里插入图片描述

==查询工资小于3000的员工姓名==

select 
    ename,sal 
from 
    emp 
where 
    sal < 3000;
在这里插入图片描述

其余可参考之前的表格,这里我不做过多演示。


条件查询between and

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';
在这里插入图片描述

条件查询 is null 、is not null

在数据库当中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

select 
    ename,sal 
from 
    emp 
where 
    sal in(3000,5000);

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;
在这里插入图片描述

觉得不错的小伙伴可以点赞关注和收藏哦!如有错误可以指出来。

<font size="4">Java学习路线目录索引</font>

image.png
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,076评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,658评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,732评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,493评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,591评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,598评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,601评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,348评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,797评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,114评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,278评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,953评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,585评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,202评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,442评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,180评论 2 367
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,139评论 2 352

推荐阅读更多精彩内容