mysql 连接查询分组_MySQL分组查询与连接查询

一,分组查询

使用ORDER BY子句将表中的数据分成若干组(还是按行显示)

语法:

SELECT 字段名[,聚集函数] FROM 表名 [WHERE子句] GROUP BY 要分组的字段名 [ORDER BY子句]

需要注意的是:在GROUP BY子句后出现的字段名必须在SELECT后的查询的字段中

1.分组查询中筛选条件分为两种:

类别

筛选数据源

在语句中的位置

使用的关键字

分组前筛选

原始数据表

GROUP BY子句前

WHERE

分组后筛选

分组后的结果集

GROUP BY子句后

HAVING

注意:

(1)能用分组前筛选(WHERE子句)完成查询优先使用分组前筛选

(2)如果聚集函数做筛选条件,则条件一定是放在HAVING子句中

2.GROUP BY子句中同时按多个字段分组

此时,GROUP BY子句后的多个字段的各个值都相同的会合并成为一行记录,就算两行记录前n-1个字段的值相同,而第n个字段的值不同也不会合并成一行而是两个不同的行。

3.添加排序

直接在GROUP BY子句后添加排序子句ORDER BY

二,连接查询

连接查询又称为多表查询。

语法:

SELECT 查询字段 FROM 表a [别名] [连接类型关键字] JOIN 表b [别名] ON 连接条件

[WHERE 筛选条件] [GROUP BY子句] [HAVING 筛选条件] [ORDER BY 排序字段]

1.按功能分类:

内连接:包括 等值连接、非等值连接、自连接

外连接:包括 左外连接、右外连接、全外连接

交叉连接:实际上就是多个表的笛卡儿积

等值连接:

在连接条件中使用符号 =

非等值连接:

在连接条件中使用除 = 外其他符号,如>,

自连接:inner

表自身的连接查询,一半这种情况下,很可能对表起两次不同的别名

需要注意的是:为表起别名后,要对查询字段进行表限定,则要使用别名去限定二不能再使用原表名了,这个和MySQL中解析SQL语句的顺序有关。

左外连接:left [outer]

以左边的表作为主表

右外连接:right [outer]

以右边的表作为主表

全外连接full [outer]

其实在MySQL中不支持圈外连接。

交叉连接:cross

左右表的笛卡儿积

2.按SQL标准分

在SQL92标准中:仅仅支持内连接

在SQL99标准中:支持内连接+外连接(左外,右外)+交叉连接

3.总结

以上总共有七种连接查询,我们用一张图来形象区分:

7792e911749045c87578ebb0690d93c3.png

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值