筛选条件

比较运算符

  • 等于: = ( 注意!不是 == )
  • 不等于: != 或 <>
  • 大于: >
  • 大于等于: >=
  • 小于: <
  • 小于等于: <=
  • IS NULL
  • IS NOT NULL

逻辑运算符

  • 与:and
  • 或:or
  • 非:not

其它操作

  • 排序:order by

    • 正序:asc
    • 倒序:desc
    • 例:select * from students order by age desc ;
  • 限制:limit
    • 控制显示m条数据:limit m
    • 从下标为m的行数开始显示n条数据:limit m,n
    • 例:select * from students limit 3,2 ;
  • 去重:distinct
    • 例:select distinct * from students;
  • 模糊查询:like
    • 任意一个字符:_
    • 任意多个字符:%
    • 例:select * from students where name like '%abc_' ;
  • 范围查询
    • 连续范围: BETWEEN a AND b 相当于a <= value <= b
    • 间隔返回: IN
    • 例:select * from students where id in(1,3,5,7);
  • 判断空值:is null 或者 is not null
  • 别名:as

聚合分组

常用聚合函数

  • 统计个数:COUNT(column)
  • 最大值:MAX(column)
  • 最小值:MIN(column)
  • 求和:SUM(column)
  • 平均值:AVG(column)
  • 列出字段全部值:GROUP_CONCAT(column)

分组查询:group by

  • 在分组的情况下,只能够出现分组字段和聚合字段
  • 其他的字段没有意义,会报错!
  • Select 字段 from 表 group by 字段;
  • Select 字段,count(*) from 表 group by 字段;

聚合筛选:having

  • 加having条件表达式,可以对输出的结果做出限制
  • Select 字段1 from 表名 group by 字段1,字段2 having 字段2>=80;

执行顺序

  • 如果一个查询语句中同时包含了别名(as),聚合函数, where, having,那么他们的执行顺序是

    • 先是执行:where
    • 然后执行:聚合函数和别名
    • 最后执行:having

子查询

将一个查询的结果留下来用于下一次查询 ( select 中嵌套 select )

要求:

  • 1) 嵌套在查询内部
  • 2) 必须始终出现在圆括号内

例:

  • 求出学生的平均年龄

    • select avg(age) from students;
  • 查找出大于平均年龄的数据
    • select * from student where age > 19;
  • 将求出的平均年龄的SQL语句用于查找大于平均年龄的语句中
    • select * from students where age > (select avg(age) from students);

连接查询

内连接:inner join

  • 无条件内连接:

    • 无条件内连接,又名交叉连接/笛卡尔连接
    • 第一张表中的每一项会和另一张表的每一项依次组合
    • select * from 表1 inner join 表2
  • 有条件内连接:
    • 在无条件内链接的基础上,加上一个on子句
    • 当连接的时候,筛选出那些有实际意义的记录来进行组合
    • select * from 表1 as a inner join 表2 as b on a.id = b.id

外连接:{left | right} join

  • 左外连接: (以左表为基准)

    • 两张表做连接的时候,在连接条件不匹配的时候
    • 留下左表中的数据,而右表中的数据以NULL填充
    • select * from 表1 as a left join 表2 as b on a.id = b.id
  • 右外连接: (以右表为基准)
    • 对两张表做连接的时候,在连接条件不匹配的时候
    • 留下右表中的数据,而左表中的数据以NULL填充
    • select * from 表1 as a right join 表2 as b on a.id = b.id

MySql 筛选条件、聚合分组、连接查询的更多相关文章

  1. 【MySQL】条件查询之排序聚合分组分页查询

    排序查询 语法:order by 子句 order by 排序字段1 排序方式1 , 排序字段2 排序方式2... 排序方式: ASC:升序,默认的. DESC:降序. 注意: 如果有多个排序条件,则 ...

  2. MySQL全面瓦解12:连接查询的原理和应用

    概述 MySQL最强大的功能之一就是能在数据检索的执行中连接(join)表.大部分的单表数据查询并不能满足我们的需求,这时候我们就需要连接一个或者多个表,并通过一些条件过滤筛选出我们需要的数据. 了解 ...

  3. mysql(4)—— 表连接查询与where后使用子查询的性能分析。

    子查询就是在一条查询语句中还有其它的查询语句,主查询得到的结果依赖于子查询的结果. 子查询的子语句可以在一条sql语句的FROM,JOIN,和WHERE后面,本文主要针对在WHERE后面使用子查询与表 ...

  4. ORM( ORM查询13种方法3. 单表的双下划线的使用 4. 外键的方法 5. 多对多的方法 ,聚合,分组,F查询,Q查询,事务 )

    必知必会13条 <1> all(): 查询所有结果 <2> get(**kwargs): 返回与所给筛选条件相匹配的对象,返回结果有且只有一个,如果符合筛选条件的对象超过一个或 ...

  5. mysql学习之路_连接查询

    回顾 列属性:主键,自增长,唯一键. 关系:一对一,一对多,多对多 三层范式: 1NF:字段设计必须符合原子性 2NF:不存在部分依赖(没有复合主键) 3NF:不存在传递依赖(实体单独成表) 逆规范化 ...

  6. MySQL数据库实验三:连接查询

    实验三    连接查询 实验名称:连接查询(2课时) 一.实验目的 理解JOIN语句的操作和基本使用方法,掌握内连接.外连接.自身连接的概念和使用. 二.实验环境 是MS SQL SERVER 200 ...

  7. MySQL数据库:多表连接查询

    多表连接查询 注意:使用连接技术建议将表经行重命名! # explain 检索连接是否达标 # 内连接 # 语法1 from 表1 inner join 表2 on 主键字段=外键字段 [where ...

  8. MySQL系列--3.数据类型和连接查询

    1.存储引擎 数据创建,查询,更新和删除操作都是通过数据引擎来进行的.不同的存储引擎存储限制不同,支持不同的索引机制等. 查询数据库支持的存储引擎 MySQL 5.7.2支持的存储引擎有:InnoDB ...

  9. mysql在group by分组后查询第二条/第三条乃至每组中任意一条数据

    昨天老板让我查询项目中(众筹),没人刚发起感召后,前三笔钱的入账时间和金额,这把大哥整懵逼了,group by在某些方面是好使,但这次不能为我所用了,获取第一笔进账是简单,可以用group by 直接 ...

随机推荐

  1. Pikachu-XSS

    XSS(跨站脚本)概述 Cross-Site Scripting 简称为“CSS”,为避免与前端叠成样式表的缩写"CSS"冲突,故又称XSS.一般XSS可以分为如下几种常见类型: ...

  2. Aery的UE4 C++游戏开发之旅(1)基础对象模型

    目录 UObject Actor种类 AActor APawn(可操控单位) AController(控制器) AGameMode(游戏模式) AHUD(HUD) ... Component种类 UA ...

  3. strcmp函数和memcmp函数的用法区别及联系

    前言: C语言中有很多东西容易搞混,最近笔者就遇到了一个问题.这里做个记录.就是memcmp和strcmp两者的用法,这里做个对比: 功能对比: A memcmp: 函数原型: int memcmp( ...

  4. 从无到有通过IDEA搭建SpringBoot项目

    本人第一次写博客希望记录当下,努力成为IT界中的清流,写的不好多多包涵. SpringBoot是由Pivotal团队在2013年开始研发.2014年4月发布第一个版本的全新开源的轻量级框架.它基于Sp ...

  5. Jmeter性能测试分布式技术

    一.什么是分布式测试 分布式测试是指通过局域网和Internet,把分布于不同地点.独立完成特定功能的测试计算机连接起来,以达到测试资源共享.分散操作.集中管理.协同工作.负载均衡.测试过程监控等目的 ...

  6. 建造者模式-C#改良实现

    区分网上已有的一般建造者模式实现,个人觉得实现太单一了,自己google查了一些好的实现,挑了其中比较适合的,做个笔记. # region 标准Builder模式实现 // 产品 class Tele ...

  7. How to: Create a Business Model in the XPO Data Model Designer 如何:在 XPO 数据模型设计器中创建业务模型

    This topic provides step-by-step instructions on how to use the XPO Data Model Designer in XAF appli ...

  8. 老师傅珍藏多年CAD常用快捷键合集,收藏,工作效率翻倍!

    想要熟练操作CAD,做一名出色的CAD绘图员,少不了勤学苦练,还要掌握一些常用的绘图命令以及常用快捷键. 今天就来跟大家分享超全的CAD绘图命令,以及常用快捷键,学会涨工资! 常用快捷键: CTRL快 ...

  9. Zeus:1 Vulnhub Walkthrough

    主机层面扫描: ╰─ nmap -p1-65535 -sV -A 10.10.202.14 PORT STATE SERVICE VERSION21/tcp open ftp vsftpd 2.0.8 ...

  10. Android五大布局详解——GridLayout(网格布局)

    GridLayout 本章以一个小的实现示例讲述: 实现效果如图: 代码实现: <?xml version="1.0" encoding="utf-8"? ...