SQL(二)- 基础查询语句

简单的查询语句(DQL)

下面我们正式来学习查询语句,下面所有查询用到的表均为前面提到的三张表:
在这里插入图片描述

员工表中的数据:
在这里插入图片描述
部门表中的数据:
在这里插入图片描述
薪资表中的数据:
在这里插入图片描述
基本查询语句的语法

select 				字段
from				表名;

1.查询员工的年薪?(字段可以参与数学运算。)

select ename,sal * 12 as '年薪' from emp;   //其中as可以省略

在这里插入图片描述
注意:标准sql语句中要求字符串使用单引号括起来。虽然mysql支持双引号,尽量别用

条件查询语句的语法

select 				3字段
from				1表名
where				2条件;

执行顺序:先from,然后where,最后select

在这里插入图片描述
1.查询工资等于5000的员工姓名?

select ename from emp where sal = 5000;

在这里插入图片描述

2.查询SMITH的工资?

select sal from emp where ename = 'SMITH'; // 字符串使用单引号括起来。

在这里插入图片描述
3.找出工资高于3000的员工?

select ename,sal from emp where sal > 3000;select ename,sal from emp where sal >= 3000;select ename,sal from emp where sal < 3000;select ename,sal from emp where sal <= 3000;

4.找出工资不等于3000的?

select ename,sal from emp where sal <> 3000;
select ename,sal from emp where sal != 3000;

5.找出工资在1100和3000之间的员工,包括1100和3000?

select ename,sal from emp where sal >= 1100 and sal <= 3000;select ename,sal from emp where sal between 1100 and 3000; // between...and...是闭区间 [1100 ~ 3000]select ename,sal from emp where sal between 3000 and 1100; // 查询不到任何数据

注意:

  • between and在使用的时候必须左小右大。
  • between and除了可以使用在数字方面之外,还可以使用在字符串方面。
select ename from emp where ename between 'A' and 'C';
select ename from emp where ename between 'A' and 'D'; // 闭区间。

6.找出哪些人津贴为NULL?
在数据库当中NULL不是一个值,代表什么也没有,为空。
空不是一个值,不能用等号衡量。
必须使用 is null或者is not null

select ename,sal,comm from emp where comm is null;select ename,sal,comm from emp where comm = null;
//结果:Empty set (0.00 sec)

在这里插入图片描述

7.找出哪些人津贴不为NULL?

select ename,sal,comm from emp where comm is not null;

在这里插入图片描述

8.找出哪些人没有津贴?

select ename,sal,comm from emp where comm is null or comm = 0;

在这里插入图片描述

9.找出工作岗位是MANAGER和SALESMAN的员工?

select ename,job from emp where job = 'MANAGER' or job = 'SALESMAN';

在这里插入图片描述

10.and和or联合起来用:找出薪资大于1000的并且部门编号是20或30部门的员工。

select ename,sal,deptno from emp where sal > 1000 and deptno = 20 or deptno = 30; // 错误的
select ename,sal,deptno from emp where sal > 1000 and (deptno = 20 or deptno = 30); // 正确的。

注意:当运算符的优先级不确定的时候加小括号。

11.in等同于or:找出工作岗位是MANAGER和SALESMAN的员工?

select ename,job from emp where job = 'SALESMAN' or job = 'MANAGER';
select ename,job from emp where job in('SALESMAN', 'MANAGER');
select ename,job from emp where sal in(800, 5000); // in后面的值不是区间,是具体的值。

在这里插入图片描述
13.not in: 不在这几个值当中。

select ename,job from emp where sal not in(800, 5000);
模糊查询like

14.找出名字当中含有O的?
(在模糊查询当中,必须掌握两个特殊的符号,一个是%,一个是_)
注意:%代表任意多个字符,_代表任意1个字符。

select ename from emp where ename like '%O%';

在这里插入图片描述

15.找出名字中第二个字母是A的?

select ename from emp where ename like '_A%';

16.找出名字中有下划线的?
新创建的表t_user:
在这里插入图片描述

select name from t_user where name like '%\_%';   // 当用到%和_时需要转译“\”

注意:当查询的记录中包含%和_时需要转译“\”

17.找出名字中最后一个字母是T的?

select ename from emp where ename like '%T';

在这里插入图片描述

排序查询(升序、降序)默认升序

排序查询格式语法

select字段
from表名
where条件
order by字段;

1.按照薪资升序,找出员工姓名和薪资:

select ename,sal from emp order by sal;  		//默认升序
select ename,sal from emp order by sal asc;		//指定升序
select ename,sal from emp order by sal desc;	//指定降序

2.按照工资降序排列,当工资相同按照名字升序排列:

select ename,sal from emp order by sal desc , ename asc;

注意:越靠前的字段越能起到主导作用。只有当前面的字段无法完成排序的时候,才会启用后面的字段。

3.找出工作岗位是SALESMAN的员工,并且要求按照薪资的降序排列。

select ename,job,sal
fromemp
where job = 'SALESMAN'
order bysal desc;
分组函数/聚合函数/多行函数(自动忽略null)

分组函数通常与group by 联合使用(having)

  • count 计数
  • sum 求和
  • avg 平均值
  • max 最大值
  • min 最小值

记住:所有的分组函数都是对“某一组”数据进行操作的。

找出工资总和?select sum(sal) from emp;
找出最高工资?select max(sal) from emp;
找出最低工资?select min(sal) from emp;
找出平均工资?select avg(sal) from emp;
找出总人数?select count(*) from emp;select count(ename) from emp;

分组函数的特点:

  1. 分组函数一共5个。
  2. 分组函数还有另一个名字:多行处理函数。
  3. 多行处理函数的特点:输入多行,最终输出的结果是1行。
  4. 分组函数自动忽略NULL。
select sum(comm) from emp;
select sum(comm) from emp where comm is not null; // 不需要额外添加这个过滤条件。sum函数自动忽略

1.找出工资高于平均工资的员工:

	select ename,sal from emp where sal > avg(sal); //报错

//报错:ERROR 1111 (HY000): Invalid use of group function

原因:SQL语句当中有一个语法规则,分组函数不可直接使用在where子句当中。

正确方法:

select ename,sal from emp where sal > (select avg(sal) from emp);
怎么解释?因为group by是在where执行之后才会执行的。

就是说,都还没分组,你怎么就执行分组函数呢?
并且任何一个分组函数(count sum avg max min)都是在group by语句执行结束之后才会执行的。

select			5字段			
from			1表名
where			2条件
group by		3分组
having			4二次过滤
order by		6
count(*)和count(具体的某个字段),他们有什么区别?

count(*):不是统计某个字段中数据的个数,而是统计总记录条数。(和某个字段无关)

count(comm): 表示统计comm字段中不为NULL的数据总数量。

分组函数也能组合起来用:

select count(*),sum(sal),avg(sal),max(sal),min(sal) from emp;

找出工资高于平均工资的员工?
第一步:找出平均工资

select avg(sal) from emp;

在这里插入图片描述
第二步:找出高于平均工资的员工

select ename,sal from emp where sal > 2073.214286;

将它们嵌套起来使用:

select ename,sal from emp where sal > (select avg(sal) from emp);
单行处理函数

什么是单行处理函数:输入一行,输出一行。

1.计算每个员工的年薪:

select ename,(sal+comm)*12 as yearsal from emp;

在这里插入图片描述

重点:所有数据库都是这样规定的,只要有NULL参与的运算结果一定是NULL。
2.使用ifnull函数

select ename,(sal+ifnull(comm,0))*12 as yearsal from emp;

在这里插入图片描述
ifnull() 空处理函数?

  • ifnull(可能含有NULL的字段,被当做什么处理) : 属于单行处理函数。
分组查询(group by 和 having + 分组函数)

group by : 按照某个字段或者某些字段进行分组。
having : having是对分组之后的数据进行再次过滤。

  • group by和 having 以及分组函数(count、avg、max、min、sum)常常搭配使用
  • having不能脱离group by单独使用,having就是为group by服务的

1.案例:找出每个工作岗位的最高薪资。

select max(sal),job from emp group by job;	

注意:

  • 分组函数一般都会和group by联合使用,这也是为什么它被称为分组函数的原因。
  • 并且任何一个分组函数(count sum avg max min)都是在group by语句执行结束之后才会执行的。
  • 当一条sql语句没有group by的话,整张表的数据会自成一组。
select ename,max(sal),job from emp group by job;  //虽然不报错,但是查询结果没意义
  • 以上在mysql当中,查询结果是有的,但是结果没有意义,在Oracle数据库当中会报错。语法错误。

  • Oracle的语法规则比MySQL语法规则严谨

  • 记住一个规则:当一条语句中有group by的话,select后面只能跟分组函数和参与分组的字段。

2.找出每个部门的最高薪资,要求显示大于2900的数据:

第一步:找出每个部门的最高薪资:select deptno,max(sal) from emp group by deptno;
第二步:再找出大于2900的数据:select deptno,max(sal) from emp group by deptno having max(sal) >2900;// 这种效率低

最佳写法:

select deptno,max(sal) from emp where sal > 2900 group by deptno;
// 这种效率高,建议能够使用where过滤的尽量使用where

where搞不定的情况:
1.找出每个部门的平均薪资,要求显示薪资大于2000的数据。

第一步:找出每个部门的平均薪资
select deptno,avg(sal) from emp group by deptno;
第二步:要求显示薪资大于2000的数据
select deptno,avg(sal) from emp group by deptno having avg(sal) > 2000;	

where后面不能使用分组函数:

select deptno,avg(sal) from emp where avg(sal) > 2000 group by deptno;	// 错误了。

这种情况只能使用having过滤。
原因:因为avg()是分完组后算出来的,max()不是分完组算出来的

总结DQL语句

select			5字段			
from			1表名
where			2条件
group by		3分组
having			4分组二次过滤
order by		6字段;
关于查询结果集的去重

关键字:distinct

1.查询所有岗位:

select distinct job from emp;   //distinct 去除重复关键字

在这里插入图片描述

2.注意:distinct的前面不能有字段

select ename distinct job from emp; //报错,distinct自能出现在所有字段的最前面

如果distinct 后有多个字段表示,后面所有字段联合去重。

3.查看每个部门的不同职位:

select distinct deptno,job from emp;

在这里插入图片描述

4.统计岗位的数量:

select count(distinct job) from emp;

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/311263.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SQL(三)- 连接查询

连接查询概念 一、什么是连接查询&#xff1f; 在实际开发中&#xff0c;大部分的情况下都不是从单张表中查询数据&#xff0c;一般都是多张表联合查询最终取出最终结果。在实际再发中&#xff0c;一般一个业务都会对应多张表&#xff0c;比如学生和班级&#xff0c;最起码两…

远程办公也可以很高效

题图&#xff1a;我的站立办公环境因为疫情&#xff0c;全中国人民都过了一个难忘的春节&#xff0c;而身在武汉的我&#xff0c;更是没有出家门半步&#xff0c;坚决做到不过国家添乱。从开始的2月14到后来的2月20日&#xff0c;再到现在的3月10日&#xff0c;官方发布的复工日…

SQL(四) - 子查询和union以及limit分页

子查询概念 什么是子查询&#xff1f;子查询都可以出现在哪里&#xff1f; select语句当中嵌套select语句&#xff0c;被嵌套的select语句是子查询。 子查询可以出现在哪里&#xff1f; select..(select). from..(select). where..(select).1.where子句中使用子查询 案例&a…

ASP.NET Core中的Http缓存

ASP.NET Core中的Http缓存Http响应缓存可减少客户端或代理对 web服务器发出的请求数。响应缓存还减少了 web服务器生成响应所需的工作量。响应缓存由 Http请求中的 header控制。而 ASP.NETCore对其都有相应的实现&#xff0c;并不需要了解里面的工作细节&#xff0c;即可对其进…

SQL(五) - 表的创建以及操作

创建表 建表语句的语法格式&#xff1a; create table 表名(字段名1 数据类型,字段名2 数据类型,字段名3 数据类型,....);MySql常用数据类型 BLOB 二进制大对象&#xff08;存储图片、视频等流媒体信息&#xff09; Binary Large OBject &#xff08;对应java中的Object&…

Istio 2020 年 Roadmap——一切为了商用

原文地址&#xff1a;https://preliminary.istio.io/zh/blog/2020/tradewinds-2020/&#xff0c;由 ServiceMesher 社区翻译。Istio 解决了人们在运行微服务时遇到的实际问题。甚至早期的预发行版本就已经可以帮助用户诊断其体系架构中的延迟&#xff0c;提高服务的可靠性以及透…

SQL(七) - 事务、索引、视图

事务&#xff08;Transaction&#xff09; 3.1、什么是事务&#xff1f; 一个事务是一个完整的业务逻辑单元&#xff0c;不可再分。 比如&#xff1a;银行账户转账&#xff0c;从A账户向B账户转账10000.需要执行两条update语句&#xff1a; update t_act set balance balan…

如何编写高性能的C#代码(二)

使用Benchmark.NET对C# 代码进行基准测试的简介在我以前的文章中[10]&#xff0c;我介绍了该系列文章[11]&#xff0c;在其中我将分享我的经验&#xff0c;同时了解C&#xff03;和.NET Core&#xff08;corefx&#xff09;框架的新性能。在本文中&#xff0c;我想着重于对现有…

如何编写高性能的C#代码(一)

原文来自互联网&#xff0c;由长沙DotNET技术社区编译。如译文侵犯您的署名权或版权&#xff0c;请联系小编&#xff0c;小编将在24小时内删除。作者介绍&#xff1a;史蒂夫戈登&#xff08;Steve Gordon&#xff09;是Microsoft MVP&#xff0c;Pluralsight的作者&#xff0c;…

从Java转向.NET/C#,Are You OK?

最近由于项目变动&#xff0c;需要用.NET/C#做开发&#xff0c;经过一段时间的学习和培训&#xff0c;对这个技术栈有了一定的理解。大家可能都知道Java和.NET/C#很像&#xff0c;这里粗略的把两者做一个对比&#xff0c;希望对感兴趣的童鞋有所帮助。如果现在有人问我&#xf…

树的节点值之和

题目背景 墨家家主有棵树。 题目描述 给定一个保存树节点信息的数据结构&#xff0c;它包含了树节点唯一的 id &#xff0c;树节点值 和 直系子节点的 id 。 比如&#xff0c;树节点1是树节点2的父节点&#xff0c;树节点2是树节点3的父节点。他们相应的树节点值为 9 , 4 , …

.NET Core开发实战(第21课:中间件:掌控请求处理过程的关键)--学习笔记(上)...

21 | 中间件&#xff1a;掌控请求处理过程的关键这一节讲解一下如何通过中间件来管理请求处理过程中间件工作原理next 表示后面有一个委托&#xff0c;每一层每一层套下去可以在任意的中间件来决定在后面的中间件之前执行什么&#xff0c;或者说在所有中间件执行完之后执行什么…

简单的二叉树创建与遍历

编一个程序&#xff0c;读入用户输入的一串先序遍历字符串&#xff0c;根据此字符串建立一个二叉树&#xff08;以指针方式存储&#xff09;。 例如如下的先序遍历字符串&#xff1a; ABC##DE#G##F### 其中“#”表示的是空格&#xff0c;空格字符代表空树。建立起此二叉树以后&…

疫情期间,千万级系统宕机N次,老板撂下狠话:没法把性提升10倍,全员解雇!...

性能调优整体思路作为一名团队技术核心&#xff0c;如何让系统跑得通、跑得稳、跑得快是必然会面对的场景。性能分析是一个大课题&#xff0c;不同的架构、不同的应用场景、不同的程序语言分析的方法若有差异&#xff0c;抽象一下大致分为两类&#xff1a;自底向上&#xff1a;…

Anaconda创建python虚拟环境

在创建虚拟环境之前首先我们需要打开命令终端&#xff1a;Win R 输入cmd 或者直接打开Anaconda Prompt&#xff08;Anaconda&#xff09; pycharm下载历史版本地址&#xff1a;https://www.jetbrains.com/pycharm/download/other.html Anaconda下载历史版本地址&#xff1a;ht…

[蓝桥杯][算法提高VIP]夺宝奇兵-递推+记忆化搜索

题目描述 在一座山上,有很多很多珠宝,它们散落在山底通往山顶的每条道路上,不同道路上的珠宝的数目也各不相同.下图为一张藏宝地图: 7 3 8 8 1 0 2 7 4 4 4 5 2 6 5 ”夺宝奇兵”从山下出发,到达山顶,如何选路才能得到最多的珠宝呢?在上图所示例子中,按照5-> 7-> 8-&g…

梯度下降与线性回归

对于代价函数&#xff1a; loss∑i(y^−yi)2loss\sum_i{(\hat{y}-y_i)}^2loss∑i​(y^​−yi​)2 loss∑i(w∗xib−yi)2loss\sum_i{(w*x_ib-y_i)}^2loss∑i​(w∗xi​b−yi​)2 最常见的代价函数&#xff1a;均方差代价函数&#xff08;Mean-Square Error&#xff0c;MSE&…

.NET Core开发实战(第21课:中间件:掌控请求处理过程的关键)--学习笔记(下)...

21 | 中间件&#xff1a;掌控请求处理过程的关键如果在 Map 的时候逻辑复杂一点&#xff0c;不仅仅判断它的 URL 地址&#xff0c;而且要做特殊的判断的话&#xff0c;可以这么做把判断逻辑变成一个委托我们要判断当我们的请求地址包含 abc 的时候&#xff0c;输出 new abcapp.…

英伟达3060Ti安装GPU版本TensorFlow2.X和Pytorch

查看Python与TensorFlow对应版本 安装GPU版本的TensorFlow的时候&#xff0c;我们需要考虑的一个问题是Python版本与TensorFlow版本的对应关系&#xff0c;可以参考下面这个链接&#xff1a; Python对应TensorFlow CPU版本 GPU版本 查看显卡驱动对应的CUDA版本并且下载安装 …

200行代码,7个对象——让你了解ASP.NET Core框架的本质[3.x版]

2019年1月19日&#xff0c;微软技术&#xff08;苏州&#xff09;俱乐部成立&#xff0c;我受邀在成立大会上作了一个名为《ASP.NET Core框架揭秘》的分享。在此次分享中&#xff0c;我按照ASP.NET Core自身的运行原理和设计思想创建了一个 “迷你版” 的ASP.NET Core框架&…