千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機構(gòu)

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  技術(shù)干貨  > sql中g(shù)roup by,having語句在select前執(zhí)行,那么為什么能用select中的別名?

sql中g(shù)roup by,having語句在select前執(zhí)行,那么為什么能用select中的別名?

來源:千鋒教育
發(fā)布人:xqq
時間: 2023-10-13 12:53:43 1697172823

一、sql中g(shù)roup by,having語句為什么能用select中的別名

SQL語句的語法順序:

FROM -> WHERE -> GROUP BY -> HAVING -> SELECT -> DISTINCT -> UNION -> ORDER BY

因此一般不能在having condition中使用select list中的alias。

但是mysql對此作了擴展。在mysql 5.7.5之前的版本,ONLY_FULL_GROUP_BY sql mode默認不開啟。在5.7.5或之后的版本默認開啟。

如果ONLY_FULL_GROUP_BY sql mode不開啟,那么mysql對標準SQL的擴展可以生效:

允許在select list、having condition和order by list中使用沒有出現(xiàn)在group by list中的字段。此時mysql會隨機選擇沒有出現(xiàn)在group by list中的字段的值。效果和使用ANY_VALUE()是相同的。允許在having condition中使用select list中的alias

— 1 以具體案例來介紹SQL的執(zhí)行順序(SQL Server)。

/*

要求:統(tǒng)計員工表里2014年1月1號及之后入職的員工所在國家、所屬年份、人數(shù),

過濾條件:以上信息里每個過國家和年份至少要對應(yīng)有兩條記錄

排序:排序時按照國家和年份降序排列。

*/

SELECT country, YEAR(hiredate) AS yearhired, COUNT(*) AS numemployees

FROM HR.Employees

WHERE hiredate >= ‘20140101’

GROUP BY country, YEAR(hiredate)

HAVING COUNT(*) > 1

ORDER BY country, yearhired DESC;

— 2 執(zhí)行順序

??? 1 FROM

??? 2 WHERE

??? 3 GROUP BY

??? 4 HAVING

??? 5 SELECT

??? 6 ORDER BY

— 3 錯誤寫法匯總(在了解了SQL的執(zhí)行順序后,不難發(fā)現(xiàn)如下的寫法是錯誤的)

— 3.1 WHERE后用SELECT后的字段別名。

SELECT country, YEAR(hiredate) AS yearhired

FROM HR.Employees

WHERE yearhired >= 2014;

–3.2? SELECT 后一字段用前面字段的別名。

SELECT empid, country, YEAR(hiredate) AS yearhired, yearhired – 1 AS prevyear

FROM HR.Employees;

–3.3 GROUP BY用SELECT里的別名

SELECT country, YEAR(hiredate) AS yearhired, COUNT(*) AS numemployees

FROM HR.Employees

WHERE hiredate >= ‘20140101’

GROUP BY country, yearhired

HAVING COUNT(*) > 1

ORDER BY country, yearhired DESC;

/* 錯誤信息

Msg 207, Level 16, State 1, Line 4

Invalid column name ‘yearhired’.

*/

— 4 特別的:Mysql SQL執(zhí)行順序和標準SQL有差異,如下SQL能正常執(zhí)行。

SELECT deptno dpt,COUNT(empno) cnt

FROM emp

WHERE deptno IN(10,20)

GROUP BY dpt

HAVING cnt > 1

延伸閱讀:

二、Django 是什么

Django 是一個高級的 Python 網(wǎng)絡(luò)框架,可以快速開發(fā)安全和可維護的網(wǎng)站。由經(jīng)驗豐富的開發(fā)者構(gòu)建,Django 負責處理網(wǎng)站開發(fā)中麻煩的部分,因此你可以專注于編寫應(yīng)用程序,而無需重新開發(fā)。 它是免費和開源的,有活躍繁榮的社區(qū),豐富的文檔,以及很多免費和付費的解決方案。

Django 可以使你的應(yīng)用具有以下優(yōu)點:

完備性

Django 遵循“功能完備”的理念,提供開發(fā)人員可能想要“開箱即用”的幾乎所有功能。因為你需要的一切都是一個”產(chǎn)品“的一部分,它們都可以無縫結(jié)合在一起,遵循一致性設(shè)計原則,并且具有廣泛和最新的文檔。

通用性

Django 可以(并已經(jīng))用于構(gòu)建幾乎任何類型的網(wǎng)站—從內(nèi)容管理系統(tǒng)和維基,到社交網(wǎng)絡(luò)和新聞網(wǎng)站。它可以與任何客戶端框架一起工作,并且可以提供幾乎任何格式(包括 HTML,Rss 源,JSON,XML 等)的內(nèi)容。你正在閱讀的網(wǎng)站就是基于 Django。

在內(nèi)部,盡管它為幾乎所有可能需要的功能(例如幾個流行的數(shù)據(jù)庫,模版引擎等)提供了選擇,但是如果需要,它也可以擴展到使用其他組件。

安全性

Django 幫助開發(fā)人員通過提供一個被設(shè)計為“做正確的事情”來自動保護網(wǎng)站的框架來避免許多常見的安全錯誤。例如,Django 提供了一種安全的方式來管理用戶賬戶和密碼,避免了常見的錯誤,比如將 session 放在 cookie 中這種易受攻擊的做法(取而代之的是 cookies 只包含一個密鑰,實際數(shù)據(jù)存儲在數(shù)據(jù)庫中)或直接存儲密碼而不是密碼哈希。

密碼哈希是通過密碼散列函數(shù)發(fā)送密碼而創(chuàng)建的固定長度值。Django 能通過運行哈希函數(shù)來檢查輸入的密碼 – 就是 – 將輸出的哈希值與存儲的哈希值進行比較是否正確。然而由于功能的“單向”性質(zhì),即時存儲的哈希值受到威脅,攻擊者也難以解決原始密碼。(但其實有彩虹表 – 譯者觀點)

默認情況下,Django 可以防范許多漏洞,包括 SQL 注入,跨站點腳本,跨站點請求偽造和點擊劫持。

聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強師集結(jié),手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內(nèi)將與您1V1溝通
免費領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學 138****2860 剛剛成功領(lǐng)取
王同學 131****2015 剛剛成功領(lǐng)取
張同學 133****4652 剛剛成功領(lǐng)取
李同學 135****8607 剛剛成功領(lǐng)取
楊同學 132****5667 剛剛成功領(lǐng)取
岳同學 134****6652 剛剛成功領(lǐng)取
梁同學 157****2950 剛剛成功領(lǐng)取
劉同學 189****1015 剛剛成功領(lǐng)取
張同學 155****4678 剛剛成功領(lǐng)取
鄒同學 139****2907 剛剛成功領(lǐng)取
董同學 138****2867 剛剛成功領(lǐng)取
周同學 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
什么是數(shù)據(jù)庫表結(jié)構(gòu)?

一、什么是數(shù)據(jù)庫表結(jié)構(gòu)數(shù)據(jù)庫表結(jié)構(gòu)是指數(shù)據(jù)庫中表的組織和定義方式。它描述了表的名稱、列(字段)的定義和屬性,以及表與其他表之間的關(guān)系。...詳情>>

2023-10-13 14:52:13
MySQL日均10萬數(shù)據(jù)永久保存實現(xiàn)高可用可以采用什么方案?

一、MySQL日均10萬數(shù)據(jù)永久保存實現(xiàn)高可用可以采用的方案1、數(shù)據(jù)庫集群使用MySQL數(shù)據(jù)庫集群來實現(xiàn)高可用性和負載均衡。可以使用主從復制(Maste...詳情>>

2023-10-13 14:47:04
類似博客這樣的圖文混排內(nèi)容在數(shù)據(jù)庫中是以什么形式保存的呢?

一、圖文混排內(nèi)容在數(shù)據(jù)庫中的保存形式在數(shù)據(jù)庫中保存類似博客這樣的圖文混排內(nèi)容,可以使用以下幾種形式:1、文本字段(Text Field)可以使用...詳情>>

2023-10-13 14:30:09
Canal將MySQL數(shù)據(jù)同步到Elasticsearch怎么保證數(shù)據(jù)一致性?

一、Canal將MySQL數(shù)據(jù)同步到Elasticsearch保證數(shù)據(jù)一致性的方法1、事務(wù)同步確保Canal捕獲到的MySQL數(shù)據(jù)是基于事務(wù)的。Canal會將整個事務(wù)的操作...詳情>>

2023-10-13 14:27:06
怎樣在數(shù)據(jù)庫中實現(xiàn)一對多的關(guān)系怎樣存儲圖片和視頻?

一、怎樣在數(shù)據(jù)庫中實現(xiàn)一對多的關(guān)系怎樣存儲圖片和視頻1.圖片和視頻文件 不要存放在數(shù)據(jù)庫中,而應(yīng)該利用文件系統(tǒng)存放,數(shù)據(jù)庫中只存放讀取他...詳情>>

2023-10-13 14:22:08
快速通道
久久亚洲中文字幕精品一区四,亚洲日本另类欧美一区二区,久久久久久久这里只有免费费精品,高清国产激情视频在线观看
在线观看911国产精品 | 午夜性色福利免费视频在线播放 | 中文字幕精品亚洲电影 | 婷婷色婷婷开心五月 | 日韩中文精品在线 | 亚洲制服丝袜在线精品 |