标签:字符串 指定 mys pat 多少 reg 信息 语法 cat
SELECT 字段1,字段2... FROM 表名
WHERE 条件
GROUP BY field
HAVING 筛选
ORDER BY field
LIMIT 限制条数
from
where
group by
having
select
distinct
order by
limit
(1)找到表:from(2)拿着where指定的约束条件,去文件/表中取出一条条记录(3)将取出的一条条记录进行分组group by,如果没有group by,则整体作为一组
(4)将分组的结果进行having过滤(5)执行select(6)去重(7)将结果按条件排序:order by(8)限制结果的显示条数
(1)select * from table; 查询表内所有数据
(2)select [字段名n1,n2...] from table; 查询指定字段数据
(3)select distinct 字段名 from table; 避免重复
(4)concat() 用于连接字符串
例如:select concat(‘姓名:‘,name) ‘姓名‘ from employee;
(5)concat_ws() 第一个参数作为分隔符
mysql> select concat_ws(‘:‘,‘姓名‘,name) ‘姓名‘ from employee;
+-------------------+
| 姓名 |
+-------------------+
| 姓名:xxx |
where常用约束:
(1)比较运算符:> 、<、>=、 <=、 <>、 !=
(2)between...and...
(3)in(值1,值2...)
(4)like ‘% or _‘ ,pattern可以是%或_ ,%表示任意多字符,_表示一个字符
(5)逻辑运算符:在多个条件直接可以使用逻辑运算符 and or not
分组是基于where之后得到的记录而进行的,
将所有记录按照某个相同字段进行归类,比如针对员工信息表的职位分组,或者按照性别进行分组等
单独使用GROUP BY关键字分组
SELECT post FROM employee GROUP BY post;
注意:我们按照post字段分组,那么select查询的字段只能是post,想要获取组内的其他相关信息,需要借助函数
GROUP BY关键字和GROUP_CONCAT()函数一起使用
SELECT post,GROUP_CONCAT(name) FROM employee GROUP BY post;#按照岗位分组,并查看组内成员名
SELECT post,GROUP_CONCAT(name) as emp_members FROM employee GROUP BY post;
GROUP BY与聚合函数一起使用
select post,count(id) as count from employee group by post;#按照岗位分组,并查看每个组有多少人
执行优先级从高到低:where > group by > having
Where 发生在分组group by之前,因而Where中可以有任意字段,但是绝对不能使用聚合函数
Having发生在分组group by之后,因而Having中可以使用分组的字段,无法直接取到其他字段,可以使用聚合函数
按单列排序
SELECT * FROM employee ORDER BY salary;
SELECT * FROM employee ORDER BY salary ASC;
SELECT * FROM employee ORDER BY salary DESC;
按多列排序:先按照age排序,如果年纪相同,则按照薪资排序
SELECT * from employee
ORDER BY age,
salary DESC;
示例:
SELECT * FROM employee ORDER BY salary DESC
LIMIT 3; #默认初始位置为0
SELECT * FROM employee ORDER BY salary DESC
LIMIT 0,5; #从第0开始,即先查询出第一条,然后包含这一条在内往后查5条
SELECT * FROM employee ORDER BY salary DESC
LIMIT 5,5; #从第5开始,即先查询出第6条,然后包含这一条在内往后查5条
SELECT * FROM employee WHERE name REGEXP ‘^ale‘;
SELECT * FROM employee WHERE name REGEXP ‘on$‘;
SELECT * FROM employee WHERE name REGEXP ‘m{2}‘;
小结:对字符串匹配的方式
WHERE name = ‘egon‘;
WHERE name LIKE ‘yua%‘;
WHERE name REGEXP ‘on$‘;
select 字段列表 from 表1,表2;
select 字段列表 from 表1 inner join 表2
on 表1.字段名 = 表2.字段名
select 字段列表 from 表1 left join 表2
on 表1.字段名 = 表2.字段名
select 字段列表 from 表1 right join 表2
on 表1.字段名 = 表2.字段名
#!mysql不支持全外连接 full JOIN
select 字段列表 from 表1 left join 表2
on 表1.字段名 = 表2.字段名
union
select 字段列表 from 表1 right join 表2
on 表1.字段名 = 表2.字段名
注:union会去掉相同记录
SELECT 字段列表 FROM 表1 INNER|LEFT|RIGHT JOIN 表2 ON 表1.字段 = 表2.字段
where condition
group by
having
order by
limit
(1)子查询是将一个查询语句嵌套在另一个查询语句中。
(2)内层查询语句的查询结果,可以为外层查询语句提供查询条件。
(3)子查询中可以包含:IN、NOT IN、ANY、ALL、EXISTS 和 NOT EXISTS等关键字
(4)还可以包含比较运算符:= 、 !=、> 、<等
标签:字符串 指定 mys pat 多少 reg 信息 语法 cat
原文地址:https://www.cnblogs.com/zhao1126/p/10236819.html