在线数据库:http://sqlfiddle.com/

建表脚本:https://gitee.com/bqzzz/sql/tree/master/Scripts

基本查询

①、查询所有记录

SELECT * FROM t_emp;

②、查询特定字段

SELECT ename,job FROM t_emp;

③、查询时指定别名

# AS可省略
SELECT
ename AS '姓名',
job AS '职位'
FROM t_emp;

④、对查询结果做运算

SELECT ename, sal*12 FROM t_emp;

条件查询

  • 算术运算符:+、-、*、/、%
  • 比较运算符:>、>=、<、<=、=、!=、IN(a,b,c)、IS NULL、IS NOT NULL、BETWEEN ... AND ...、LIKE、REGEXP
  • 逻辑运算符:AND、OR、NOT、XOR
  • 按位运算符:&、|、~、^ 、<<、>>
SELECT * FROM t_emp WHERE (deptno=10 OR deptno=20) AND sal>2000;

注:WHERE子句中的条件表达式的执行顺序从左到右,应尽量把索引条件、筛选掉最多记录的条件写在左侧。

分页查询

# LIMIT + 起始位置,偏移量
SELECT * FROM t_emp LIMIT 0,5; # 查询前五条数据 简写
SELECT * FROM t_emp LIMIT 5;

排序

# 默认升序
SELECT * FROM t_emp ORDER BY sal; # 降序
SELECT * FROM t_emp ORDER BY sal DESC; # 指定多个排序规则,当第一个规则无法排序时使用第二个,以此类推,兜底使用主键来排序
SELECT * FROM t_emp
ORDER BY sal DESC,hiredate DESC;

去重

# DISTINCT用于筛去结果集中完全相同的记录
SELECT DISTINCT deptno FROM t_emp;
SELECT DISTINCT deptno,job FROM t_emp;

聚合查询

聚合函数可以对查询到的记录做简单的计算,常用聚合函数:

函数 说明
AVG (列名) 平均值
COUNT (列名) 非空记录数
MAX (列名) 非空最大值
MIN (列名) 非空最小值
SUN (列名) 合计

示例:

SELECT SUM(sal) FROM t_emp ;
SELECT SUM(IFNULL(sal,0)) FROM t_emp ; SELECT AVG(IFNULL(sal,0)) FROM t_emp ;
SELECT MAX(IFNULL(sal,0)) FROM t_emp ;
SELECT MIN(IFNULL(sal,0)) FROM t_emp ; SELECT COUNT(*) FROM t_emp ;
SELECT COUNT(sal) FROM t_emp ;

注:聚合函数是对查询结果做统计,不能用在WHERE条件子句中。

分组查询

一般使用GROUP BY子句将结果集分组处理,用法示例:

SELECT deptno,AVG(sal) FROM t_emp GROUP BY deptno;

如果分组后的结果集还需要再分组,可使用逐级分组

SELECT deptno,job,AVG(sal) FROM t_emp
GROUP BY deptno,job
ORDER BY deptno,AVG(sal) DESC;

如果需要对分组的结果再做相应的汇总计算,使用WITH ROLLUP

SELECT deptno,AVG(sal) FROM t_emp
GROUP BY deptno WITH ROLLUP;

如果使用 GROP BY 子句,SELECT子句就只能出现 分组列 和 聚合函数,不能出现其他列的字段,如果需要获得某个字段对应结果集(如获得按班级分组后,要显示每个班对应的人)可以使用 GROP_CONCAT 函数,将该字段拼接成字符串显示:

SELECT deptno,COUNT(*),GROUP_CONCAT(ename) FROM t_emp
GROUP BY deptno ;

使用 HAVING 子句

由于WHERE子句的优先级高,执行WHERE时还没有检索出数据,所以WHERE子句中不能使用聚合函数。

但如果有这样查询逻辑:查询部门平局工资大于2000的部门

# 这样查肯定报错,要配合HAVING子句
SELECT deptno FROM t_emp
WHERE AVG(sal)>=2000
GROUP BY deptno; # 使用HAVING子句配合GROUP BY字句做筛选,HAVING子句在GROUP BY后执行
SELECT deptno FROM t_emp
GROUP BY deptno HAVING AVG(sal)>=2000;

注:HAVING子句与WHERE子句的功能类似,但普通条件还是要用WHERE条件,WHERE执行顺序靠前,可以提前剔除大量无关数据

查询语句的执行顺序:FROM -> WHERE -> GROUP BY -> SELECT -> ORDER BY -> LIMIT

MySQL:单表查询的更多相关文章

  1. Mysql 单表查询 子查询 关联查询

    数据准备: ## 学院表create table department( d_id int primary key auto_increment, d_name varchar(20) not nul ...

  2. python 3 mysql 单表查询

    python 3 mysql 单表查询 1.准备表 company.employee 员工id id int 姓名 emp_name varchar 性别 sex enum 年龄 age int 入职 ...

  3. Mysql 单表查询-排序-分页-group by初识

    Mysql 单表查询-排序-分页-group by初识 对于select 来说, 分组聚合(((group by; aggregation), 排序 (order by** ), 分页查询 (limi ...

  4. Mysql 单表查询where初识

    Mysql 单表查询where初识 准备数据 -- 创建测试库 -- drop database if exists student_db; create database student_db ch ...

  5. MySQL单表查询

    MySQL之单表查询 创建表 # 创建表 mysql> create table company.employee5( id int primary key AUTO_INCREMENT not ...

  6. python mysql 单表查询 多表查询

    一.外键 变种: 三种关系: 多对一 站在左表的角度: (1)一个员工 能不能在 多个部门? 不成立 (2)多个员工 能不能在 一个部门? 成立 只要有一个条件成立:多 对 一或者是1对多 如果两个条 ...

  7. mysql 单表查询

    一 单表查询的语法 SELECT 字段1,字段2... FROM 表名 WHERE 条件 GROUP BY field HAVING 筛选 ORDER BY field LIMIT 限制条数   二 ...

  8. SQL学习笔记四(补充-1)之MySQL单表查询

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

  9. python开发mysql:单表查询&多表查询

    一 单表查询,以下是表内容 一 having 过滤 1.1 having和where select * from emp where id > 15; 解析过程;from > where ...

  10. 0x06 MySQL 单表查询

    一 单表查询语法 SELECT 字段1,字段2... FROM 表名 WHERE 条件 GROUP BY field HAVING 筛选 ORDER BY field LIMIT 限制条数 二 关键字 ...

随机推荐

  1. 【洛谷 p3372】模板-线段树 1(数据结构--线段树)

    题目:已知一个数列,你需要进行下面两种操作:1.将某区间每一个数加上x:2.求出某区间每一个数的和. 解法:如题,模版题.需要加上 lazy 标记,也就是我的 upd.lazy 标记的思路就是对一个结 ...

  2. HDU - 3374 String Problem (kmp求循环节+最大最小表示法)

    做一个高产的菜鸡 传送门:HDU - 3374 题意:多组输入,给你一个字符串,求它最小和最大表示法出现的位置和次数. 题解:刚刚学会最大最小表示法,amazing.. 次数就是最小循环节循环的次数. ...

  3. Codeforces Global Round 11 C. The Hard Work of Paparazzi (DP)

    题意:有\(r\)X\(r\)的网格图,有\(n\)位名人,会在\(t_i\)时出现在\((x_i,y_i)\),如果过了\(t_i\)名人就会消失,从某一点走到另外一点需要花费的时间是它们之间的曼哈 ...

  4. WSL2 新建dotnet core mvc项目

    我们知道dotnet sdk会有很多命令,但在我们完全不知道如何去使用哪个命令. 我们使用dotnet -h进行查看: 我们看到SDK的new命令,但是new命令又如何使用呢? 我们再次使用帮助: 可 ...

  5. 大数据去重(data deduplication)方案

    数据去重(data deduplication)是大数据领域司空见惯的问题了.除了统计UV等传统用法之外,去重的意义更在于消除不可靠数据源产生的脏数据--即重复上报数据或重复投递数据的影响,使计算产生 ...

  6. 数理统计9:完备统计量,指数族,充分完备统计量法,CR不等式

    昨天我们给出了统计量是UMVUE的一个必要条件:它是充分统计量的函数,且是无偏估计,但这并非充分条件.如果说一个统计量的无偏估计函数一定是UMVUE,那么它还应当具有完备性的条件,这就是我们今天将探讨 ...

  7. 信号量解决写者优先&读者优先&公平竞争(reader writer)

    先说问题: 这里的rand都是伪随机.解决也很简单,srand即可.内容懒得改了~~ 描述及思路:           代码:           运行结果:   读者优先:           效果 ...

  8. sqll-libs(3)

    单引号测试,最外层单引号错误信息near ''1'') LIMIT 0,1' at line 1 由此我们可以确定SQL后台语句为select * from table where id =('inp ...

  9. Ubuntu 18.04 + pip3 install virtualenvwrapper 找不到virtualenvwrapper.sh

    Reference Ubuntu 18.04 只自带python3.6.5, 因此不想装python2了, 但通过apt install 装virtualenvwrapper时发现必须得装python ...

  10. Chrome DevTools & performance & keywords

    Chrome DevTools & performance & keywords performance / 优化性能 https://developers.google.com/we ...