一.简单查询
-- 创建表
DROP TABLE IF EXISTS `person`;
CREATE TABLE `person` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(50) NOT NULL,
`age` tinyint(4) DEFAULT ‘0‘,
`sex` enum(‘男‘,‘女‘,‘人妖‘) NOT NULL DEFAULT ‘人妖‘,
`salary` decimal(10,2) NOT NULL DEFAULT ‘250.00‘,
`hire_date` date NOT NULL,
`dept_id` int(11) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=13 DEFAULT CHARSET=utf8;
-- 创建数据
-- 教学部
INSERT INTO `person` VALUES (‘1‘, ‘alex‘, ‘28‘, ‘人妖‘, ‘53000.00‘, ‘2010-06-21‘, ‘1‘);
INSERT INTO `person` VALUES (‘2‘, ‘wupeiqi‘, ‘23‘, ‘男‘, ‘8000.00‘, ‘2011-02-21‘, ‘1‘);
INSERT INTO `person` VALUES (‘3‘, ‘egon‘, ‘30‘, ‘男‘, ‘6500.00‘, ‘2015-06-21‘, ‘1‘);
INSERT INTO `person` VALUES (‘4‘, ‘jingnvshen‘, ‘18‘, ‘女‘, ‘6680.00‘, ‘2014-06-21‘, ‘1‘);
-- 销售部
INSERT INTO `person` VALUES (‘5‘, ‘歪歪‘, ‘20‘, ‘女‘, ‘3000.00‘, ‘2015-02-21‘, ‘2‘);
INSERT INTO `person` VALUES (‘6‘, ‘星星‘, ‘20‘, ‘女‘, ‘2000.00‘, ‘2018-01-30‘, ‘2‘);
INSERT INTO `person` VALUES (‘7‘, ‘格格‘, ‘20‘, ‘女‘, ‘2000.00‘, ‘2018-02-27‘, ‘2‘);
INSERT INTO `person` VALUES (‘8‘, ‘周周‘, ‘20‘, ‘女‘, ‘2000.00‘, ‘2015-06-21‘, ‘2‘);
-- 市场部
INSERT INTO `person` VALUES (‘9‘, ‘月月‘, ‘21‘, ‘女‘, ‘4000.00‘, ‘2014-07-21‘, ‘3‘);
INSERT INTO `person` VALUES (‘10‘, ‘安琪‘, ‘22‘, ‘女‘, ‘4000.00‘, ‘2015-07-15‘, ‘3‘);
-- 人事部
INSERT INTO `person` VALUES (‘11‘, ‘周明月‘, ‘17‘, ‘女‘, ‘5000.00‘, ‘2014-06-21‘, ‘4‘);
-- 鼓励部
INSERT INTO `person` VALUES (‘12‘, ‘苍老师‘, ‘33‘, ‘女‘, ‘1000000.00‘, ‘2018-02-21‘, null);
-- 创建表 DROP TABLE IF EXISTS `person`; CREATE TABLE `person` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(50) NOT NULL, `age` tinyint(4) DEFAULT ‘0‘, `sex` enum(‘男‘,‘女‘,‘人妖‘) NOT NULL DEFAULT ‘人妖‘, `salary` decimal(10,2) NOT NULL DEFAULT ‘250.00‘, `hire_date` date NOT NULL, `dept_id` int(11) DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB AUTO_INCREMENT=13 DEFAULT CHARSET=utf8; -- 创建数据 -- 教学部 INSERT INTO `person` VALUES (‘1‘, ‘alex‘, ‘28‘, ‘人妖‘, ‘53000.00‘, ‘2010-06-21‘, ‘1‘); INSERT INTO `person` VALUES (‘2‘, ‘wupeiqi‘, ‘23‘, ‘男‘, ‘8000.00‘, ‘2011-02-21‘, ‘1‘); INSERT INTO `person` VALUES (‘3‘, ‘egon‘, ‘30‘, ‘男‘, ‘6500.00‘, ‘2015-06-21‘, ‘1‘); INSERT INTO `person` VALUES (‘4‘, ‘jingnvshen‘, ‘18‘, ‘女‘, ‘6680.00‘, ‘2014-06-21‘, ‘1‘); -- 销售部 INSERT INTO `person` VALUES (‘5‘, ‘歪歪‘, ‘20‘, ‘女‘, ‘3000.00‘, ‘2015-02-21‘, ‘2‘); INSERT INTO `person` VALUES (‘6‘, ‘星星‘, ‘20‘, ‘女‘, ‘2000.00‘, ‘2018-01-30‘, ‘2‘); INSERT INTO `person` VALUES (‘7‘, ‘格格‘, ‘20‘, ‘女‘, ‘2000.00‘, ‘2018-02-27‘, ‘2‘); INSERT INTO `person` VALUES (‘8‘, ‘周周‘, ‘20‘, ‘女‘, ‘2000.00‘, ‘2015-06-21‘, ‘2‘); -- 市场部 INSERT INTO `person` VALUES (‘9‘, ‘月月‘, ‘21‘, ‘女‘, ‘4000.00‘, ‘2014-07-21‘, ‘3‘); INSERT INTO `person` VALUES (‘10‘, ‘安琪‘, ‘22‘, ‘女‘, ‘4000.00‘, ‘2015-07-15‘, ‘3‘); -- 人事部 INSERT INTO `person` VALUES (‘11‘, ‘周明月‘, ‘17‘, ‘女‘, ‘5000.00‘, ‘2014-06-21‘, ‘4‘); -- 鼓励部 INSERT INTO `person` VALUES (‘12‘, ‘苍老师‘, ‘33‘, ‘女‘, ‘1000000.00‘, ‘2018-02-21‘, null);
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 |
|
二 条件查询
条件查询:使用 WHERE 关键字 对简单查询的结果集 进行过滤
1. 比较运算符: > < >= <= = <>(!=)
2. null 关键字: is null , not null
3.逻辑运算符: 与 and 或 or (多个条件时,需要使用逻辑运算符进行连接)
1 2 3 4 5 6 7 8 9 10 11 12 |
|
三 区间查询
关键字 between 10 and 20 :表示 获得10 到 20 区间的内容
1 2 3 4 |
|
四 集合查询
关键字: in, not null
1 2 3 4 5 6 |
|
五 模糊查询
关键字 like , not like
%: 任意多个字符
_ : 只能是单个字符
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 |
|
六 排序查询
关键字: ORDER BY 字段1 DESC, 字段2 ASC
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 |
|
七 聚合函数
聚合: 将分散的聚集到一起.
聚合函数: 对列进行操作,返回的结果是一个单一的值,除了 COUNT 以外,都会忽略空值
COUNT:统计指定列不为NULL的记录行数;
SUM:计算指定列的数值和,如果指定列类型不是数值类型,那么计算结果为0;
MAX:计算指定列的最大值,如果指定列是字符串类型,那么使用字符串排序运算;
MIN:计算指定列的最小值,如果指定列是字符串类型,那么使用字符串排序运算;
AVG:计算指定列的平均值,如果指定列类型不是数值类型,那么计算结果为0;
1 2 3 4 5 |
|
八 分组查询
分组的含义: 将一些具有相同特征的数据 进行归类.比如:性别,部门,岗位等等
怎么区分什么时候需要分组呢?
套路: 遇到 "每" 字,一般需要进行分组操作.
例如: 1. 公司每个部门有多少人.
2. 公司中有 多少男员工 和 多少女员工.
#分组查询格式: select 被分组的字段 from 表名 group by 分组字段 [having 条件字段] ps: 分组查询可以与 聚合函数 组合使用. #查询每个部门的平均薪资 select avg(salary),dept from person GROUP BY dept; #查询每个部门的平均薪资 并且看看这个部门的员工都有谁? select avg(salary),dept,GROUP_CONCAT(name) from person GROUP BY dept; #GROUP_CONCAT(expr):按照分组,将expr字符串按逗号分隔,组合起来 #查询平均薪资大于10000的部门, 并且看看这个部门的员工都有谁? select avg(salary),dept,GROUP_CONCAT(name) from person GROUP BY dept; having avg(salary)>10000;
where 与 having区别:
#执行优先级从高到低:where > group by > having
#1. Where 发生在分组group by之前,因而Where中可以有任意字段,但是绝对不能使用聚合函数。
#2. Having发生在分组group by之后,因而Having中可以使用分组的字段,无法直接取到其他字段,可以使用聚合函数
九 分页查询
好处:限制查询数据条数,提高查询效率
1 2 3 4 5 6 7 8 9 10 |
|
十 正则表达式
MySQL中使用 REGEXP 操作符来进行正则表达式匹配。
模式 | 描述 |
---|---|
^ | 匹配输入字符串的开始位置。 |
$ | 匹配输入字符串的结束位置。 |
. | 匹配任何字符(包括回车和新行) |
[...] | 字符集合。匹配所包含的任意一个字符。例如, ‘[abc]‘ 可以匹配 "plain" 中的 ‘a‘。 |
[^...] | 负值字符集合。匹配未包含的任意字符。例如, ‘[^abc]‘ 可以匹配 "plain" 中的‘p‘。 |
p1|p2|p3 | 匹配 p1 或 p2 或 p3。例如,‘z|food‘ 能匹配 "z" 或 "food"。‘(z|f)ood‘ 则匹配 "zood" 或 "food"。 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 |
|
正则详情参考 :http://www.cnblogs.com/wangfengming/articles/8067037.html
十一 SQL 语句关键字的执行顺序
查询:姓名不同人员的最高工资,并且要求大于5000元,同时按最大工资进行排序并取出前5条.
1 2 3 4 5 6 7 8 9 10 11 12 13 |
|
在上面的示例中 SQL 语句的执行顺序如下:
(1). 首先执行 FROM 子句, 从 person 表 组装数据源的数据
(2). 执行 WHERE 子句, 筛选 person 表中 name 不为 NULL 的数据
(3). 执行 GROUP BY 子句, 把 person 表按 "name" 列进行分组
(4). 计算 max() 聚集函数, 按 "工资" 求出工资中最大的一些数值
(5). 执行 HAVING 子句, 筛选工资大于 5000的人员.
(7). 执行 ORDER BY 子句, 把最后的结果按 "Max 工资" 进行排序.
(8). 最后执行 LIMIT 子句, . 进行分页查询
执行顺序: FROM -> WHERE -> GROUP BY -> HAVING -> SELECT -> ORDER BY ->limit
十二 练习题
练习题一: http://www.cnblogs.com/wangfengming/articles/7944029.html
练习题二: http://www.cnblogs.com/wangfengming/articles/7889786.html
原文地址:https://www.cnblogs.com/qunxiadexiaoxiangjiao/p/8480677.html