MySQL:单表查询
在线数据库: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:单表查询的更多相关文章
- Mysql 单表查询 子查询 关联查询
数据准备: ## 学院表create table department( d_id int primary key auto_increment, d_name varchar(20) not nul ...
- python 3 mysql 单表查询
python 3 mysql 单表查询 1.准备表 company.employee 员工id id int 姓名 emp_name varchar 性别 sex enum 年龄 age int 入职 ...
- Mysql 单表查询-排序-分页-group by初识
Mysql 单表查询-排序-分页-group by初识 对于select 来说, 分组聚合(((group by; aggregation), 排序 (order by** ), 分页查询 (limi ...
- Mysql 单表查询where初识
Mysql 单表查询where初识 准备数据 -- 创建测试库 -- drop database if exists student_db; create database student_db ch ...
- MySQL单表查询
MySQL之单表查询 创建表 # 创建表 mysql> create table company.employee5( id int primary key AUTO_INCREMENT not ...
- python mysql 单表查询 多表查询
一.外键 变种: 三种关系: 多对一 站在左表的角度: (1)一个员工 能不能在 多个部门? 不成立 (2)多个员工 能不能在 一个部门? 成立 只要有一个条件成立:多 对 一或者是1对多 如果两个条 ...
- mysql 单表查询
一 单表查询的语法 SELECT 字段1,字段2... FROM 表名 WHERE 条件 GROUP BY field HAVING 筛选 ORDER BY field LIMIT 限制条数 二 ...
- SQL学习笔记四(补充-1)之MySQL单表查询
阅读目录 一 单表查询的语法 二 关键字的执行优先级(重点) 三 简单查询 四 WHERE约束 五 分组查询:GROUP BY 六 HAVING过滤 七 查询排序:ORDER BY 八 限制查询的记录 ...
- python开发mysql:单表查询&多表查询
一 单表查询,以下是表内容 一 having 过滤 1.1 having和where select * from emp where id > 15; 解析过程;from > where ...
- 0x06 MySQL 单表查询
一 单表查询语法 SELECT 字段1,字段2... FROM 表名 WHERE 条件 GROUP BY field HAVING 筛选 ORDER BY field LIMIT 限制条数 二 关键字 ...
随机推荐
- CENTOS7 使用YUM安装MARIADB
现在在服务器配置数据库,一般都会直接配置MariaDB,它可以实现mysql数据库连接. 1.安装MariaDB 安装命令 yum -y install mariadb mariadb-server ...
- HDU-6881 Tree Cutting (HDU多校D10T5 点分治)
HDU-6881 Tree Cutting 题意 \(n\) 个点的一棵树,要求删除尽量少的点,使得删点之后还是一棵树,并且直径不超过 \(k\),求删除点的数量 分析 补题之前的一些错误想法: 尝试 ...
- 【洛谷 p3381】模板-最小费用最大流(图论)
题目:给出一个网络图,以及其源点和汇点,每条边已知其最大流量和单位流量费用,求出其网络最大流和在最大流情况下的最小费用. 解法:在Dinic的基础下做spfa算法. 1 #include<cst ...
- 【uva 1312】Cricket Field(算法效率--技巧枚举)
题意:一个 L*R 的网格里有 N 棵树,要求找一个最大空正方形并输出其左下角坐标和长.(1≤L,R≤10000, 0≤N≤100) 解法:枚举空正方形也就是枚举空矩阵,先要固定一个边,才好继续操作. ...
- Bubble Cup 13 - Finals [Online Mirror, unrated, Div. 1] K. Lonely Numbers (数学)
题意:定义两个数\(a,b\)是朋友,如果:\(gcd(a,b)\),\(\frac{a}{gcd(a,b)}\),\(\frac{b}{gcd(a,b)}\)能构成三角形,现在给你一个正整数\(n\ ...
- java——字符串常量池、字符串函数以及static关键字的使用、数组的一些操作函数、math函数
字符串常量池: 字符串比较函数: 字符串常用方法: 字符串截取函数: 字符串截取函数: static关键字使用: 要调用类中的static类型的变量的时候,可以用"类名.变量名&quo ...
- Codeforces Round #327 (Div. 1) C. Three States
C. Three States time limit per test 5 seconds memory limit per test 512 megabytes input standard inp ...
- AWS注册到连接
1. 注册AWS账号 https://www.cnblogs.com/cmt/p/13912814.html 2.注册完成之后,选择实例 Ubuntu,下载xxx.pem文件,查看实例得到ip 比如我 ...
- servlet相关知识点
一.servlet的生命周期 Servlet(Sever Applet),全称是Java Servlet,是用java编写的服务器程序.Servlet是指任何实现了这个Servlet接口的类. ser ...
- 2019牛客多校第四场B xor(线性基求交)题解
题意: 传送门 给\(n\)个集合,每个集合有一些数.给出\(m\)个询问,再给出\(l\)和\(r\)和一个数\(v\),问你任意的\(i \in[l,r]\)的集合,能不能找出子集异或为\(v\) ...