DQL基礎(chǔ)應(yīng)用(select,from,where,group by,having,order by,limit,distinct,union)

1.select語句應(yīng)用

1.1.select 的執(zhí)行邏輯
命令參數(shù) 作用
select 列1离熏,列2
from 表,指定從哪個表中取數(shù)據(jù)
where 條件颁糟,匹配條件遵馆,and/or是并且/或者,between是取區(qū)間,in表示取哪些值的屬性芍阎。
group by 條件,分組字句+聚合函數(shù)應(yīng)用
having 條件,把之前的結(jié)果再次進行過濾
order by 條件矛渴,將之前的結(jié)果進行排序,默認由低到高desc由高到低
limit 條件惫搏,取行數(shù)具温,顯示多少行
1.2.select單獨使用情況

(1) select @@參數(shù)名;

SELECT @@datadir;                             查詢數(shù)據(jù)目錄路徑
SELECT @@port                                 查詢端口號
SELECT @@socket                               查詢socket文件路徑
SELECT @@innodb_flush_log_at_trx_commit;
SHOW VARIABLES                                查詢所有參數(shù)(513個)
SHOW VARIABLES LIKE '%trx%';                  模糊查詢

(2) select函數(shù)();

SELECT NOW()                                  查看當前時間
SELECT DATABASE();                            查看當前所在數(shù)據(jù)庫
SELECT USER()                                 查看當前用戶
SELECT 16*16                                  計算16*16
SELECT CONCAT("hello word")                   顯示引號中的值
SELECT CONCAT(USER,"@",HOST) FROM mysql.user        查詢user和host使用'@'符合拼接顯示

2.FROM 子句應(yīng)用

SELECT * FROM city                            查看citi表中所用數(shù)據(jù),全表掃描
SELECT NAME,countrycode FROM city;            查看citi表中的name列和countrycode列

from用于指定從哪個表中取數(shù)據(jù)

3. where字句應(yīng)用

>>3.1 等值查詢
--- 查詢中國城市的信息.
SELECT * FROM city WHERE countrycode='CHN'

>>3.2 不等值查詢
--- 查詢ID小于10的城市信息
SELECT * FROM city WHERE population<100;
--- 查詢不是中國的城市信息(盡量不使用不等于,可能不走索引)
SELECT * FROM city WHERE countrycode!='CHN';

>>3.3 模糊查詢
---查詢國家代號為CH打頭的城市信息.
SELECT * FROM city WHERE countrycode LIKE 'CH%'
《注意:避免使用LIKE中前面帶%的模糊查詢》

>>3.4 邏輯連接符(and筐赔,or)
---查詢中國城市人口超過500W的城市信息
SELECT * FROM city WHERE CountryCode='CHN' AND Population>5000000
---查看山東省或河北省的城市信息
SELECT * FROM city WHERE district='shangdong' OR district='hebei' 

>>3.5 where 配合between and使用
---查詢?nèi)丝跀?shù)在100W-200W區(qū)間的城市信息(包含頭尾)
SELECT * FROM city WHERE Population BETWEEN 1000000 AND 2000000

>>3.6 where配合in使用
---查看山東省或河北省的城市信息
SELECT * FROM city WHERE District IN('shangdong','hebei')
《  排除:SELECT * FROM city WHERE District NOT IN('shangdong','hebei')  》

where用于匹配條件铣猩,and/or是并且/或者,between是取區(qū)間,in表示取哪些值的屬性茴丰。

4. group by 分組字句+聚合函數(shù)應(yīng)用

4.1 什么是分組

按照某個列進行分組

4.2 常用的聚合函數(shù)
名稱 作用
COUNT() 計數(shù)
MAX() 最大值
MIN() 最小值
AVG() 平均值
SUM() 求和
GROUP_CONCAT() 列轉(zhuǎn)行
4.3 例子
>>統(tǒng)計每個國家的城市個數(shù)
SELECT CountryCode,COUNT(id) FROM city GROUP BY CountryCode
>> 統(tǒng)計中國,每個省的,城市個數(shù),省總?cè)丝跀?shù)
SELECT district, COUNT(NAME),SUM(population)  FROM  city   WHERE countrycode='CHN'  GROUP BY district ;
>>統(tǒng)計各個國家的城市名列表
SELECT countrycode ,GROUP_CONCAT(NAME) FROM city GROUP BY countrycode\G

5. having子句使用

>> 統(tǒng)計中國,每個省的,城市個數(shù),省總?cè)丝跀?shù)达皿,只顯示人口總數(shù)大于800w的省
SELECT district, COUNT(NAME),SUM(population) 
FROM  city  
WHERE countrycode='CHN' 
GROUP BY district 
HAVING  SUM(population)>8000000

having是把之前的結(jié)果再次進行過濾

6. order by子句使用

>> 將以上例子在進行排序
SELECT district, COUNT(NAME),SUM(population) 
FROM  city  
WHERE countrycode='CHN' 
GROUP BY district 
HAVING  SUM(population)>8000000
ORDER BY SUM(population) DESC;
>>查詢中國所有城市信息,并以人口數(shù)降序排序輸出
SELECT * FROM city WHERE CountryCode='CHN' ORDER BY Population DESC;

order by是將之前的結(jié)果進行排序

7. limit 應(yīng)用

>>查詢中國所有城市信息贿肩,并以人口降序輸出峦椰,只顯示前五名
SELECT * FROM city WHERE CountryCode='CHN' ORDER BY Population DESC LIMIT 5;
>>跳過N行,顯示M行
LIMIT N OFFSET M
LIMIT N,M

limit是取行數(shù)汰规,顯示多少行汤功。

8. distinct應(yīng)用

>>查詢所有國家代號信息(去重)
SELECT DISTINCT CountryCode FROM city;

9. union與union all(相當于and)

>>查看山東省或者河北省的
SELECT * FROM city WHERE District='shangdong' UNION ALL SELECT * FROM city WHERE district='hebei'

面試題:union和union的區(qū)別
UNION自帶distinct的去重功能,UNION ALL沒有去重復(fù)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末溜哮,一起剝皮案震驚了整個濱河市滔金,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌茬射,老刑警劉巖鹦蠕,帶你破解...
    沈念sama閱讀 222,729評論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異在抛,居然都是意外死亡钟病,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,226評論 3 399
  • 文/潘曉璐 我一進店門刚梭,熙熙樓的掌柜王于貴愁眉苦臉地迎上來肠阱,“玉大人,你說我怎么就攤上這事朴读∫倥牵” “怎么了?”我有些...
    開封第一講書人閱讀 169,461評論 0 362
  • 文/不壞的土叔 我叫張陵衅金,是天一觀的道長噪伊。 經(jīng)常有香客問我簿煌,道長,這世上最難降的妖魔是什么鉴吹? 我笑而不...
    開封第一講書人閱讀 60,135評論 1 300
  • 正文 為了忘掉前任姨伟,我火速辦了婚禮,結(jié)果婚禮上豆励,老公的妹妹穿的比我還像新娘夺荒。我一直安慰自己,他們只是感情好良蒸,可當我...
    茶點故事閱讀 69,130評論 6 398
  • 文/花漫 我一把揭開白布技扼。 她就那樣靜靜地躺著,像睡著了一般嫩痰。 火紅的嫁衣襯著肌膚如雪剿吻。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,736評論 1 312
  • 那天始赎,我揣著相機與錄音和橙,去河邊找鬼。 笑死造垛,一個胖子當著我的面吹牛魔招,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播五辽,決...
    沈念sama閱讀 41,179評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼办斑,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了杆逗?” 一聲冷哼從身側(cè)響起乡翅,我...
    開封第一講書人閱讀 40,124評論 0 277
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎罪郊,沒想到半個月后蠕蚜,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,657評論 1 320
  • 正文 獨居荒郊野嶺守林人離奇死亡悔橄,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,723評論 3 342
  • 正文 我和宋清朗相戀三年靶累,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片癣疟。...
    茶點故事閱讀 40,872評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡挣柬,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出睛挚,到底是詐尸還是另有隱情邪蛔,我是刑警寧澤,帶...
    沈念sama閱讀 36,533評論 5 351
  • 正文 年R本政府宣布扎狱,位于F島的核電站侧到,受9級特大地震影響勃教,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜床牧,卻給世界環(huán)境...
    茶點故事閱讀 42,213評論 3 336
  • 文/蒙蒙 一荣回、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧戈咳,春花似錦、人聲如沸壕吹。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,700評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽耳贬。三九已至踏堡,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間咒劲,已是汗流浹背顷蟆。 一陣腳步聲響...
    開封第一講書人閱讀 33,819評論 1 274
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留腐魂,地道東北人帐偎。 一個月前我還...
    沈念sama閱讀 49,304評論 3 379
  • 正文 我出身青樓,卻偏偏與公主長得像蛔屹,于是被迫代替她去往敵國和親削樊。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 45,876評論 2 361

推薦閱讀更多精彩內(nèi)容