MySQL基础——DQL语言的学习(条件查询)

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介: DQL语言学习进阶二(条件查询)

DQL语言学习进阶二(条件查询)


一、语法

select 查询列表 from 表名 where 筛选条件;

(顺序:from,where,select)


二、分类


(一)按条件表达式筛选

简单条件运算符:> < = != <> >= <= <=>


例1:查询工资大于12000的员工信息

select*from employee where salary >12000

例2:查询部门编号不等于90号的员工名和部门编号

select last_name,department_id 
from employee 
where department_id !=90;

(二)按逻辑表达式筛选

逻辑运算符: and or not

作用:用于连接条件表达式

and(&&):两个条件都为true,结果为true,反之为false;

or(||):只要有一个条件为true,结果为true,反之为false;

not(|):如果连接的条件本身为false,结果为true,反之为false。


例1:查询工资在10000到20000之间的员工名、工资及奖金

select last_name,salary,commission_pct
from employee 
where salary>=1000and  salary<=20000;

例2:查询部门编号不是在90到110之间,或者工资高于15000的员工信息

方式一:
select*from employee
where department_id<90or department_id>110or salary>15000;方式二:
select*from employee 
wherenot( department_id>=90and department_id <=110)or salary>15000;

(三)模糊查询

复杂条件运算符:like  between and  in  is null / is not null


1、like:

(1)一般和通配符搭配使用,可以判断字符型或数值型通配符:

%:任意多个字符,包含0个字符

_:任意单个字符


例1:查询员工名中包含字符a的员工信息

select*from employee where last_name like'% a %';

例2:查询员工名中第三个字符为e,第五个字符为a的员工名和工资

select last_name, salary from employee where last_name like'__e_a%';

例3:查询员工名中第二个字符为_的员工名

方式一:
select last_name from employee where last_name like'_\_%';方式二:
select last_name from employee 
where last_name like'_$_%' escape '$';


(#escape 转义)


2、between and

(1)使用 between and 可以提高语句的简洁度

(2)包含临界值

(3)两个临界值不要调换顺序

例1:查询员工编号在100到120之间的员工信息

方式一:
select*from employee 
where employee_id >=100and employee_id <=120;方式二:
select*from employee where employee_id between100and120;

3、in

含义:判断某字段的值是否属于in列表中的某一项

特点:

(1)使用in提高语句简洁度

(2)in列表中的值类型必须一致或兼容

(3)不支持通配符的使用

例:查询员工的工种编号是IT_PROG,AD_VP,AD_PRES中的一个员工名和工种编号

方式一:
select last_name, job_id from employee 
where job_id ='IT_PROG'or job_id ='AD_VP'or job_id ='AD_PRES';方式二:
select last_name, job_id from employee 
where job_id in('IT_PROG','AD_VP','AD_PRES');

4、is null

=或<>不能用于判断null值

is null或is not null可以判断null值

例1:查询没有奖金的员工名和奖金率

select last_name, comission_pct 
from employee 
where comission isnull;

例2:查询有奖金的员工名和奖金率

select last_name, comission_pct 
from employee 
where comission isnotnull;

安全等于:<=>

例1:查询没有奖金的员工名和奖金率

select last_name, comission_pct 
from employee 
where comission <=>null;

例2:查询工资为12000的员工信息

select last_name, salary 
from employee 
where salary <=>12000;

is null PK <=>

is null:仅仅可以判断null值,可读性高

<=>:既可以判断null值,又可以判断普通数值,可读性较低

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
5天前
|
存储 关系型数据库 MySQL
提高MySQL查询性能的方法有很多
提高MySQL查询性能的方法有很多
42 6
|
5天前
|
存储 关系型数据库 MySQL
提高MySQL的查询性能
提高MySQL的查询性能
25 4
|
1天前
|
关系型数据库 MySQL 数据库
mysql的查询
MySQL数据库查询语句的基本用法,包括基础查询、条件查询、排序、分组查询、聚合函数的使用以及分页查询的方法。
8 2
|
1天前
|
缓存 关系型数据库 MySQL
MySQL 满足条件函数中使用查询最大值函数
MySQL 满足条件函数中使用查询最大值函数
9 1
|
1天前
|
SQL 关系型数据库 MySQL
MySQL 查询某个字段含有字母数字的值
MySQL 查询某个字段含有字母数字的值
7 0
|
1天前
|
关系型数据库 MySQL 数据库
MySQL 查询结果求和详解
MySQL 查询结果求和详解
6 0
|
3天前
|
Kubernetes 关系型数据库 MySQL
k8s学习--利用helm部署应用mysql,加深helm的理解
k8s学习--利用helm部署应用mysql,加深helm的理解
|
24天前
|
NoSQL 关系型数据库 MySQL
微服务架构下的数据库选择:MySQL、PostgreSQL 还是 NoSQL?
在微服务架构中,数据库的选择至关重要。不同类型的数据库适用于不同的需求和场景。在本文章中,我们将深入探讨传统的关系型数据库(如 MySQL 和 PostgreSQL)与现代 NoSQL 数据库的优劣势,并分析在微服务架构下的最佳实践。
|
26天前
|
存储 SQL 关系型数据库
使用MySQL Workbench进行数据库备份
【9月更文挑战第13天】以下是使用MySQL Workbench进行数据库备份的步骤:启动软件后,通过“Database”菜单中的“管理连接”选项配置并选择要备份的数据库。随后,选择“数据导出”,确认导出的数据库及格式(推荐SQL格式),设置存储路径,点击“开始导出”。完成后,可在指定路径找到备份文件,建议定期备份并存储于安全位置。
192 11
|
1天前
|
SQL 关系型数据库 MySQL