ci mysql 搜索_Mysql查询详解(条件查询、子查询、模糊查询、连接查询。。。)...

一、创建数据库和数据表

775001bbedba

在这里插入图片描述

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;

775001bbedba

在这里插入图片描述

给查询列起别名

SELECT ename,sal as '工资' from emp;

注意:字符串要使用单引号括起来,尽量别使用双引号

775001bbedba

在这里插入图片描述

三、条件查询

条件查询需要用到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;

775001bbedba

在这里插入图片描述

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

select

ename,sal

from

emp

where

sal < 3000;

775001bbedba

在这里插入图片描述

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

条件查询between and

between and 在使用的时候必须是左小右大

select

ename,sal

from

emp

where

sal between 2000 and 3000;

775001bbedba

在这里插入图片描述

between and 还可以使用在字符串方面(左为闭区间,右为开区间)

select

ename

from

emp

where

ename between 'A' and 'C';

775001bbedba

在这里插入图片描述

条件查询 is null 、is not null

在数据库当中NULL不是一个值,代表什么也没有,为空。空不是一个值,不能用等号判断,必须使用 is null 或 is not null 进行判断。

查询comm为null的数据

select

ename,comm

from

emp

where

comm is null;

775001bbedba

在这里插入图片描述

查询comm为不为null的数据

select

ename,comm

from

emp

where

comm is not null;

775001bbedba

在这里插入图片描述

条件查询 in

select

ename,sal

from

emp

where

sal in(3000,5000);

in:sal值为3000和5000的数据

775001bbedba

在这里插入图片描述

select

ename,sal

from

emp

where

sal not in(3000,5000);

not in:sal不在(3000,5000)这几个值中

775001bbedba

在这里插入图片描述

四、模糊查询

==搭配%使用==

%代表一个或多个字符的通配符

(1)

select

ename,sal

from

emp

where

ename like '%S%';

ename like '%S%'; 名称中带有S的名字

775001bbedba

在这里插入图片描述

(2)

select

ename,sal

from

emp

where

ename like 'S%';

查询名称中开始字符为S的数据

775001bbedba

在这里插入图片描述

(3)

select

ename,sal

from

emp

where

ename like '%S';

插叙名称中最后一个字符为S的数据

775001bbedba

在这里插入图片描述

==搭配_使用==

_代表仅仅一个字符的通配符

select

ename,sal

from

emp

where

ename like 'KIN_';

775001bbedba

在这里插入图片描述

五、分组查询

group by :按照某个字段或者某些字段进行分组

having:having是对分组之后的数据进行再次过滤。

select

AVG(sal),deptno

from

emp

group by

deptno;

775001bbedba

在这里插入图片描述

select

deptno

from

emp

group by

deptno

having

deptno >= 20;

775001bbedba

在这里插入图片描述

==注意事项==

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;

775001bbedba

在这里插入图片描述

非等值连接

特点:连接条件是非等量关系

找出每个员工的工资等级,要求显示员工名、工资、工资等级

select

e.ename,e.sal,s.grade

from

emp e

join

salgrade s

on

e.sal between s.losal and s.hisal;

775001bbedba

在这里插入图片描述

自连接

特点:一张表当成两张表。自己连接自己

找出每个员工的上级领导,要求显示员工名和对应的领导名称

select

e.ename,m.ename

from

emp e

left join

emp m

on

e.mgr = m.empno;

775001bbedba

在这里插入图片描述

外连接

假设A和B表进行连接,使用外连接的话,AB两张表中有一张表是主表,一张表是副表,主要查询主表中的数据,捎带着查询副表,当副表中的数据没有和主表中的数据匹配上,副表自动模拟出NULL与之匹配。

外连接分类

左外连接(左连接):表示左边的这张表是主表。

右外连接(右连接):表示右边的这张表是主表。

#基本语法

左表 left/right join 右表 on 左表.字段=右表.字段

七、子查询

==1、where后面嵌套子查询==

select

ename,sal

from

emp

where

sal > (select avg(sal) from emp);

775001bbedba

在这里插入图片描述

==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;

775001bbedba

在这里插入图片描述

3、select后面嵌套子查询

查询每个员工所在部门名称

select

e.ename,d.dname,

(select d.dname from dept d where e.deptno = d.deptno) as dname

from

emp e;

775001bbedba

在这里插入图片描述

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

775001bbedba

image.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值