欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MYSQL??group?by?有哪些注意事項

 更新時間:2022年07月05日 10:37:17   作者:??Java中文社群??  
這篇文章主要介紹了MYSQL??group?by?有哪些注意事項,比如我們不能在?group?by?之后添加?where?查詢語句,更多相關(guān)分享,需要的朋友可以參考下面文章內(nèi)容

前言:

注意:本文以下內(nèi)容基于 MySQL 5.7 InnoDB 數(shù)據(jù)庫引擎。

1.group by 后面不能加 where

在 MySQL 中,所有的 SQL 查詢語法要遵循以下語法順序:

  • select
  • from
  • where
  • group by
  • having
  • order by
  • limit

以上語法順序是不能前后互換的,否則報錯。比如我們不能在 group by 之后添加 where 查詢語句,否則會出現(xiàn)如下錯誤: 

 語法順序的執(zhí)行是和 MySQL 的 select 語句執(zhí)行順序相關(guān)的,select 執(zhí)行先后順序如下:

  • from 階段
  • where 階段
  • group 階段
  • having 階段
  • select 階段
  • order by 階段
  • limit 階段

注意:其中 select 比較特殊,在進行查詢語句編寫時,要寫在最前面,其余語法順序要和執(zhí)行先后順序保持一致。

2.having 或 group by 可單獨使用

having 和 group by 可以單獨使用,如下查詢所示: 

3.having 和 group by 可使用別名

**當 having 單獨使用時,它的作用和 where 類似,但又有細微的不同。**比如在 where 中不能使用別名,但 having 和 group by 卻可以別名。咱們創(chuàng)建一個測試表來演示一下,建表 SQL 如下:

drop table if exists student_score;
create table student_score(
    id int primary key auto_increment comment '主鍵',
    name varchar(250) comment '姓名',
    math decimal(4,1) comment '數(shù)學成績',
    chinese decimal(4,1) comment '語文成績'
);
insert into student_score(name,math,chinese) values('張三',50,50),('李四',80,80),('王五',90,90);

表中的數(shù)據(jù)如下圖所示: 

 當我們使用總成績別名 total 分別在 where 和 having 中使用時,查詢結(jié)果如下: 

 從上述結(jié)果可以看出,having 查詢可以使用 select 中的別名,而 where 不能使用別名。 除了 having 可以使用別名之外,group by 也可以使用別名,

如下圖所示: 

為什么where不能用別名?為having卻可以?

where 中不能使用別名,這和 MySQL 語句執(zhí)行順序有關(guān),MySQL 語句執(zhí)行順序如下:

  • from 階段
  • where 階段
  • group 階段
  • having 階段
  • select 階段
  • order by 階段
  • limit 階段

也就是說,**在執(zhí)行 where 查詢時,select 還沒執(zhí)行,因此在 where 中想要使用還未執(zhí)行的 select 中的別名是不行的。**那從上面的執(zhí)行順序可以看到,having 執(zhí)行也在 select 之前,為什么它就可以使用 select 中的別名呢?

這是因為 MySQL 在 5.7.5 之后做了擴展,允許在 having 中使用別名,官方文檔中有相應的說明,

如下圖所示: 

 MySQL 官方文檔地址:

PS:group by 能使用別名的原理和 having 類似。

總結(jié)

SQL 語句編寫一定要遵循此先后順序:select、from、where、group by、having、order by、limit。其中 having 或 group by 都可單獨使用,并且在 MySQL 5.7.5 之后,group by 和 having 可以使用別名查詢,但 where 不能使用別名。

到此這篇關(guān)于MYSQL group by 有哪些注意事項?的文章就介紹到這了,更多相關(guān)MYSQL group by內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評論