一、条件查询

1、含义:前面学的基础查询可以查询一个或多个字段,如果需要的数据仅仅是其中的某一行或多行就用到了条件查询。

2、语法:(序号表示语句执行顺序)

SELECT 字段名   ③
FROM 表名 ①
WHERE 筛选条件; ②

3、筛选条件

#1条件运算符:
> < = <> >= <=
#2逻辑运算符:
&& || !
#3模糊查询:
like、between and、in、is null

案例一:查询所有员工中工资大于10000的员工名、工资(条件运算符+起别名+点语法)

SELECT last_name,salary
FROM employees e #起别名
WHERE e.`salary`>10000; #点语法访问表中的字段

注意:在from中给表employees起别名后where中再使用employees.salary是错误的

案例二:查询所有员工中工资大于5000并且部门编号大于105的员工信息(逻辑运算符+起别名)

SELECT *
FROM employees e
WHERE e.`salary`>5000 && e.`department_id`>105;

注意:MySQL中支持&&但推荐使用 AND、OR分别代替&&、||

案例三:查询所有员工中姓名第二个字母位'k'且工资在1000到20000之间的员工信息(模糊查询)

SELECT *
FROM employees e
WHERE e.`last_name` LIKE '_k%' AND e.`salary` BETWEEN 1000 AND 20000;

补充:

1、通配符:(使用like的模糊查询中用到)

①'%'在通配符中代表任意长度任意字符,其中任意长度可为0

②'_'在通配符中代表长度为1的任意字符

③如果要查询的字段中包含'%'、'_' 可以使用转义符'\'或自定义转义符,例如:

案例:查询员工姓名中包含'_'的员工信息

//使用'\'作为转义符(默认)
SELECT *
FROM employees e
WHERE e.`last_name` LIKE '%\_%' ;
//自定义转义符,使用escape关键字
SELECT *
FROM employees e
WHERE e.`last_name` LIKE '%$_%' ESCAPE '$';

2、between ... and ... :

①两者之间均可满足(不可等于临界值)

②between  numa and numb,numa与numb的位置不可交换即必须满足:numa<=numb

3、模糊查询(in):

语法:

last_name in('a','b','c');

注意:

①括号中多个元素在一起时逗号隔开

②当last_name与括号中至少一个字符串完全一直时才会被筛选出来

4、模糊查询(is null):

语法:

last_name is null;

注意:MySQL中不能直接使用 ' == '来判空,但使用安全等于 ' <=> ' 可判空也可判定其它任意类型的数据

二、排序查询

1、含义:排序查询可将查询出的数据按照特定字段的数值按由小到大或由大到小排序。

2、语法:(执行顺序如序号所示)

SELECT 字段名      ④
FROM 表名 ①
【WHERE 筛选条件】 ②
ORDER BY 排序方式; ③

注意:

①排序方式分为两种ASC(升序)、DESC(降序)

②OREDER BY子句一般在查询语句的最后面,除了limit子句

案例:查询全体员工中薪资大于8000的员工姓名并将薪资按升序排列(排序查询+起别名)

SELECT last_name,salary
FROM employees e
WHERE e.`salary`>8000
ORDER BY e.`salary` ASC;

三、分组查询

1、单行函数:

①字符函数:
SELECT LENGTH('hello world!'); 返回括号中所占总字节数(多数函数返回字符数,仅该函数返回字节数)
SELECT CONCAT('str1','str2','str3'); 将括号中多个字符串拼接成一个长的字符串
SELECT UPPER('str'),LOWER('STR'); 变大、小写
SELECT SUBSTR('str',a,b); 在str中从第a位开始截取长度为b的字符串(第一个字符索引为1)
SELECT REPLACE('str','str1','str2');将str中的str1全部替换为str2
②数学函数
SELECT ROUND(1.345,2); 将1.345保留2位小数的四舍五入
SELECT CEIL(0.9),FLOOR(1.1); 将0.9向上取整,将1.1向下取整
SELECT TRUNCATE(1.55555,2); 保留两位小数
SELECT MOD(10,9); 取余(10%9)
③日期函数
SELECT NOW(); 打印当前时间
SELECT DATE_FORMAT(NOW(),'%Y年%m月%d日'); 将标准日期类型(datetime)的数据转化为字符串(varchar)
SELECT STR_TO_DATE('1998-3-2','%Y-%c-%d') AS out_put; 将字符串(varchar)转化为指定日期类型
④流程控制函数(只举一例if函数)
SELECT IF(3>2,end1,end2); 当3>2成立时,执行end1,否则执行end2

2、分组函数

求和:sum()、均值:avg()、最大值:max()、最小值:min()、求数目:count()、求日期差(天):datediff()

注意:用法在下面的分组查询中会详细讲解

3、分组查询

1、含义:题目中出现’ 每个 ‘的时候一般要使用分组查询,即:将整个表的数据按某个性质分成n组(理解不了就直接看案例)

2、语法:

SELECT 字段名或分组函数
FROM 表名
【WHERE 筛选条件】
GROUP BY 分组依据
ORDER BY 排序方式

案例一:查询每个部门的最低工资(起别名+分组排序)

理解:题中出现每个,要用分组排序,查询每个部门的最低工即:先将所有人按部门编号分成多组,再从每组中选出最低工资

SELECT MIN(salary) 最低工资,department_id 部门编号
FROM employees
GROUP BY department_id;

运行结果:

案例二:查询每个管理者手下员工的最低工资,并且最低工资不能低于6000,没有管理者的员工不计算在内

题目比较复杂分两步做:

①按照manage_id分组,从中选出最低工资

SELECT MIN(salary),manager_id
FROM employees
WHERE manager_id IS NOT NULL
GROUP BY manager_id;

②筛选最低工资大于等于6000的数据

SELECT MIN(salary),manager_id
FROM employees
WHERE manager_id IS NOT NULL
GROUP BY manager_id
HAVING MIN(salary)>=6000;

注意:既然也是筛选为什么用的时having?

where筛选与having筛选的区别:分组前筛选用where,分组后筛选用having。

-------------------------------------------------------------------------------------------------------------------------------------------------------------------------

复习整理,如有错误请指出。

(四)MySQL条件查询(通配符、模糊查询)、排序查询、分组查询(单行、分组函数)的更多相关文章

  1. (5)MySQL的查询:模糊查询(通配符查询like)、限制符查询(limit)、排序查询(order by)、分组查询(group by)、(子查询)

    注意事项 指令语法的优先级: where > group by >order by > limit 例:select count(id) as cnt,age from tablen ...

  2. MySQL之单表查询 一 单表查询的语法 二 关键字的执行优先级(重点) 三 简单查询 四 WHERE约束 五 分组查询:GROUP BY 六 HAVING过滤 七 查询排序:ORDER BY 八 限制查询的记录数:LIMIT 九 使用正则表达式查询

    MySQL之单表查询 阅读目录 一 单表查询的语法 二 关键字的执行优先级(重点) 三 简单查询 四 WHERE约束 五 分组查询:GROUP BY 六 HAVING过滤 七 查询排序:ORDER B ...

  3. MySQL之多表查询一 介绍 二 多表连接查询 三 符合条件连接查询 四 子查询 五 综合练习

    MySQL之多表查询 阅读目录 一 介绍 二 多表连接查询 三 符合条件连接查询 四 子查询 五 综合练习 一 介绍 本节主题 多表连接查询 复合条件连接查询 子查询 首先说一下,我们写项目一般都会建 ...

  4. 18 12 06 sql 的 基本语句 查询 条件查询 逻辑运算符 模糊查询 范围查询 排序 聚合函数 分组 分页 连接查询 自关联 子查询

    -- 数据的准备 -- 创建一个数据库 create database python_test charset=utf8; -- 使用一个数据库 use python_test; -- 显示使用的当前 ...

  5. 四 mysql之单表查询

    目录 一 单表查询的语法 二 关键字的执行优先级(重点) 三 简单查询 四 WHERE约束 五 分组查询:GROUP BY 1. 什么是分组?为什么要分组? 2. ONLY_FULL_GROUP_BY ...

  6. MySQL的外键,修改表,基本数据类型,表级别操作,其他(条件,通配符,分页,排序,分组,联合,连表操作)

    MySQL的外键,修改表,基本数据类型,表级别操作,其他(条件,通配符,分页,排序,分组,联合,连表操作): a.创建2张表 create table userinfo(nid int not nul ...

  7. MySQL的ALTER变更、正则查询、分组查询、排序查询以及事务查询的概

    MySQL的表和字段信息的变更 ALTER TABLE table-name DROP column-name; #删除某个字段 ALTER TABLE table-name ADD column-n ...

  8. MySQL使用笔记(七)排序和限制数据记录查询

    By francis_hao    Dec 17,2016 排序数据记录查询 排序是指将筛选出符合条件的数据进行有序排放,有升序(ASC(默认))方式和降序(DESC)方式. mysql> se ...

  9. MySQL进阶5--分组函数 / 分组排序和分组查询 group by(having) /order by

    MySQL进阶--分组排序和分组查询 group by(having) /order by /* 介绍分组函数 功能:用做统计使用,又称为聚合函数或组函数 1.分类: sum, avg 求和 /平均数 ...

随机推荐

  1. 一、工具类DBUtil——数据库连接

    这个工具类完成的工作如下: 1.第一个static方法,完成数据库初始化的工作 2.第二个static方法,完成与数据库建立连接的工作. package util; import java.sql.C ...

  2. ShoneSharp语言(S#)的设计和使用介绍系列(5)— 数值Double

    ShoneSharp语言(S#)的设计和使用介绍 系列(5)— 数值Double 作者:Shone 声明:原创文章欢迎转载,但请注明出处,https://www.cnblogs.com/ShoneSh ...

  3. Centos 安装 Anaconda

    # 首先从 Anaconda 官网下载 anaconda Linux 64Bit 版本命令行安装包 $ wget https://repo.continuum.io/archive/Anaconda3 ...

  4. Pyqt5_QWidget

    QWidget常用方法: Qwidget.size()#获得客户区的大小 QWidget.width().QWidget.height()#获得客户区的宽度与高度 #设置不可以变宽.高 QWidget ...

  5. linux 去除^M 换行符

    一般,在windows下写的shell脚本,都会去linux执行,都会有^M 符号,那么怎么去除呢? 第一种方法:cat -A filename 就可以看到windows下的断元字符 ^M要去除他,最 ...

  6. 抛开 Spring ,你知道 MyBatis 加载 Mapper 的底层原理吗?

    原文链接:抛开 Spring ,你知道 MyBatis 加载 Mapper 的底层原理吗? 大家都知道,利用 Spring 整合 MyBatis,我们可以直接利用 @MapperScan 注解或者 @ ...

  7. 基于 abp vNext 和 .NET Core 开发博客项目 - 定时任务最佳实战(三)

    上一篇(https://www.cnblogs.com/meowv/p/12974439.html)完成了全网各大平台的热点新闻数据的抓取,本篇继续围绕抓取完成后的操作做一个提醒.当每次抓取完数据后, ...

  8. vnc安装 VNC的安装以及使用[转]

    VNC (Virtual Network Console)是虚拟网络控制台的缩写.它 是一款优秀的远程控制工具软件,由著名的 AT&T 的欧洲研究实验室开发的.VNC 是在基于 UNIX 和  ...

  9. jchdl - GSL实例:FullAdder(使用HalfAdder实现)

    https://mp.weixin.qq.com/s/5mcYAllizuxyr3QSNrotrw 全加器是能够计算低位进位的二进制加法电路.与半加器相比,全加器不只考虑本位计算结果是否有进位,也考虑 ...

  10. MyBatis(二)参数传递和自定义结果集

    个人博客网:https://wushaopei.github.io/    (你想要这里多有) 一.myBatis的注解使用方式 package com.webcode.mapper; import ...