SQL學(xué)習(xí)指南

這篇文章介紹一些SQL中常用的語句,主要介紹查詢語句,以Mysql作為例子;
在查詢之前先插入數(shù)據(jù)毅厚,

insert into table values( ... ...);

括號中是插入的字段值;

SQL最小化的查詢結(jié)構(gòu)如下:

select column from table;

table是我們的表名浦箱,column是我們想要查詢的字段/列吸耿,column可以用 * 代替,指代全部字段酷窥,意為從table表查詢所有數(shù)據(jù)咽安。
如,

select * from user;
where的用法

where 是基礎(chǔ)查詢語法,用于條件判斷蓬推。

select * from user where nickname = "Steve";

也可以用 and or 進(jìn)行多條件判斷,其中條件之間可以使用括號區(qū)別不同的and or條件妆棒。

select * from user where nickname = "Steve" and first_name = "Steve";

當(dāng)我們遇到字段數(shù)據(jù)類型是數(shù)值時(shí),也可以使用符號> 、>=糕珊、< 动分、<=、!= 進(jìn)行邏輯判斷红选,!= 指的是不等于澜公,等價(jià)于 <>;
當(dāng)我們需要取區(qū)間數(shù)值時(shí),使用 between and;
如纠脾,

select * from DataAnalyst where companyId between 10000 and 20000

如果要模糊查找玛瘸,能用like蜕青;

select * from DataAnalyst where positionName like '%mysql%'

語句的含義是在positionName列查找包含「mysql」字段的數(shù)據(jù)苟蹈,%代表的是通配符,含義是無所謂「mysql」前面后面是什么內(nèi)容右核。
還有其他常用的語法比如not慧脱,代表邏輯的逆轉(zhuǎn),常見not in贺喝、not like菱鸥、not null等。

group by

group by是數(shù)據(jù)分析中常見的語法躏鱼,目的是將數(shù)據(jù)按組/維度劃分氮采。類似于Excel中的數(shù)據(jù)透視表;
如,

select city,count(1) from DataAnalyst group by city

在mysql中染苛,如果使用的是only_full_group_by模式鹊漠,需要修改才可以訪問全部的字段參考解決方案

如果某個(gè)統(tǒng)計(jì)的字段有重復(fù)的值,可使用distinct來消除重復(fù);

select city,count(distinct positionId) from DataAnalyst group by city

sql 中也有if語句茶行,

select city,
          count(distinct positionId),
          count(if(industryField like '%電子商務(wù)%',positionId,null)) 
from DataAnalyst
group by city

if函數(shù)中間的字段代表為true時(shí)返回的值躯概,不過因?yàn)榘貜?fù)數(shù)據(jù),我們需要將其改成positionId;

having語句畔师,它對聚合后的數(shù)據(jù)結(jié)果進(jìn)行過濾;

select city,count(distinct positionId) from DataAnalyst
group by city having count(distinct positionId) >= 500 
子查詢

將一個(gè)查詢的結(jié)果作為數(shù)據(jù)源來再次查詢娶靡;

select city from ( select * from customer where state = 'MA') as t group by city;;

括號中的就是父數(shù)據(jù)源,其中需要使用as 來定義一個(gè)別名看锉;

order by語句姿锭,對查詢到的數(shù)據(jù)進(jìn)行排序;

select * from customer order by city;

默認(rèn)是升序伯铣,如要降序:在后面加一個(gè)desc就好呻此;

常用函數(shù)

now()創(chuàng)建出一個(gè)時(shí)間字段,就能獲得當(dāng)前的系統(tǒng)時(shí)間懂傀;
date() 獲得當(dāng)前日期趾诗,week函數(shù)獲得當(dāng)前第幾周,month函數(shù)獲得當(dāng)前第幾個(gè)月。其余還包括恃泪,quarter郑兴,year,day贝乎,hour情连,minute;
date_add函數(shù)對時(shí)間進(jìn)行加減法;

select date_add(date(now()),interval 1 day);

改變1為負(fù)數(shù)览效,可達(dá)到減法的目的却舀,也能更改day為week、year等锤灿,進(jìn)行其他時(shí)間間隔的運(yùn)算;
datediff(date1,date2)或者timediff(time1,time2) 求兩個(gè)時(shí)間的間隔;

left挽拔、right、mid等函數(shù)但校,得到字符的一部分螃诅,這里和Excel一樣;

select left(salary,1) from DataAnalyst

subset函數(shù)與mid等價(jià);
locate函數(shù)查找字符所在的位置;

select locate("k",salary),salary from DataAnalyst
關(guān)系

SQL 中可以將不同的表連接起來組成一張新表状囱,使查詢變得更加的強(qiáng)大术裸;
使用join將兩個(gè)表聯(lián)接起來,這是inner join 的簡寫亭枷,

select * from business as b join customer as c on b.cust_id = c.cust_id;

字段可能重名袭艺,所以一旦使用了join,字段前應(yīng)該加上表名;
除了join叨粘,還有l(wèi)eft join猾编,right join,outer join等,這個(gè)我們可以用數(shù)學(xué)中的交集和并集來類比。

7cb720e5b6b540c69ddc3a4fcab1a146.png

當(dāng)我們有多個(gè)字段要匹配時(shí)宣鄙,on后面可以通過 and 進(jìn)行多項(xiàng)關(guān)聯(lián);
如袍镀,

select * from A
join B on A.name = B.name and A.phone = B.phone and B.sex = '男

SQL 還有一個(gè)外鍵的概念,可以使用外鍵來作為兩個(gè)表關(guān)聯(lián)的約束冻晤;

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末苇羡,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子鼻弧,更是在濱河造成了極大的恐慌设江,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,888評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件攘轩,死亡現(xiàn)場離奇詭異叉存,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)度帮,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,677評論 3 399
  • 文/潘曉璐 我一進(jìn)店門歼捏,熙熙樓的掌柜王于貴愁眉苦臉地迎上來稿存,“玉大人,你說我怎么就攤上這事瞳秽“曷模” “怎么了?”我有些...
    開封第一講書人閱讀 168,386評論 0 360
  • 文/不壞的土叔 我叫張陵练俐,是天一觀的道長袖迎。 經(jīng)常有香客問我,道長腺晾,這世上最難降的妖魔是什么燕锥? 我笑而不...
    開封第一講書人閱讀 59,726評論 1 297
  • 正文 為了忘掉前任,我火速辦了婚禮悯蝉,結(jié)果婚禮上归形,老公的妹妹穿的比我還像新娘。我一直安慰自己泉粉,他們只是感情好连霉,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,729評論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著嗡靡,像睡著了一般。 火紅的嫁衣襯著肌膚如雪窟感。 梳的紋絲不亂的頭發(fā)上讨彼,一...
    開封第一講書人閱讀 52,337評論 1 310
  • 那天,我揣著相機(jī)與錄音柿祈,去河邊找鬼哈误。 笑死,一個(gè)胖子當(dāng)著我的面吹牛躏嚎,可吹牛的內(nèi)容都是我干的蜜自。 我是一名探鬼主播,決...
    沈念sama閱讀 40,902評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼卢佣,長吁一口氣:“原來是場噩夢啊……” “哼重荠!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起虚茶,我...
    開封第一講書人閱讀 39,807評論 0 276
  • 序言:老撾萬榮一對情侶失蹤戈鲁,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后嘹叫,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體婆殿,經(jīng)...
    沈念sama閱讀 46,349評論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,439評論 3 340
  • 正文 我和宋清朗相戀三年罩扇,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了婆芦。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,567評論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖消约,靈堂內(nèi)的尸體忽然破棺而出癌压,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 36,242評論 5 350
  • 正文 年R本政府宣布,位于F島的核電站鹰晨,受9級特大地震影響子巾,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜秋泳,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,933評論 3 334
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧泡挺,春花似錦、人聲如沸命浴。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,420評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽生闲。三九已至媳溺,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間碍讯,已是汗流浹背悬蔽。 一陣腳步聲響...
    開封第一講書人閱讀 33,531評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留捉兴,地道東北人蝎困。 一個(gè)月前我還...
    沈念sama閱讀 48,995評論 3 377
  • 正文 我出身青樓,卻偏偏與公主長得像倍啥,于是被迫代替她去往敵國和親禾乘。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,585評論 2 359

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