數(shù)據(jù)庫筆記-SQL表連接

表操作

創(chuàng)建表

CREATE TABLE mytable (
  # int 類型屑宠,不為空拂到,自增
  id INT NOT NULL AUTO_INCREMENT,
  # int 類型帅刊,不可為空走芋,默認(rèn)值為 1全闷,不為空
  col1 INT NOT NULL DEFAULT 1,
  # 變長字符串類型叉寂,最長為 45 個字符,可以為空
  col2 VARCHAR(45) NULL,
  # 日期類型总珠,可為空
  col3 DATE NULL,
  # 設(shè)置主鍵為 id
  PRIMARY KEY (`id`));

修改表

添加列

ALTER TABLE mytable
ADD col CHAR(20);

刪除列

ALTER TABLE mytable
DROP COLUMN col;

刪除表

DROP TABLE mytable;

表連接

關(guān)系型數(shù)據(jù)庫屏鳍,一個表就是數(shù)據(jù)之間的關(guān)系,而表與表的關(guān)系連接局服,使得復(fù)雜查詢(query)成為可能钓瞭。

SQL的連接三種:內(nèi)連接、外連接和交叉連接淫奔。

下面以極客時間專欄《SQL 必知必會》的 NBA數(shù)據(jù)庫為例山涡。

內(nèi)連接INNER JOIN

交叉連接 CROSS JOIN

笛卡爾積連接,是SQL92 標(biāo)準(zhǔn)的一種連接方法唆迁,類似 SQL99的CROSS JOIN鸭丛,返回連接的表格的笛卡爾積,返回結(jié)果的行數(shù)等于兩個表行數(shù)的乘積唐责。

查詢語句:

SELECT * FROM player, team;

結(jié)果:


SQL99標(biāo)準(zhǔn)的CROSS JOIN

查詢語句:

SELECT * FROM player CROSS JOIN team;

結(jié)果:


如果一次要 CROSS JOIN連接多個表鳞溉,寫法如下:

SELECT * 
FROM t1 CROSS JOIN t2 
CROSS JOIN t3;

等值連接(自然連接)

查詢語句:

SELECT player_id, player.team_id, player_name, height, team_name 
FROM player, team 
WHERE player.team_id = team.team_id;

使用別名的寫法:

SELECT player_id, a.team_id, player_name, height, team_name 
FROM player AS a, team AS b 
WHERE a.team_id = b.team_id;

等同于SQL99 標(biāo)準(zhǔn)的「自然連接」。
無需指定等值的字段鼠哥。

SELECT player_id, team_id, player_name, height, team_name 
FROM player NATURAL JOIN team;

結(jié)果如下:

ON連接寫法:

SELECT player_id, player.team_id, player_name, height, team_name 
FROM player JOIN team ON player.team_id = team.team_id;

非等值連接

查詢語句:

SELECT p.player_name, p.height, h.height_level
FROM player AS p, height_grades AS h
WHERE p.height BETWEEN h.height_lowest AND h.height_highest;

結(jié)果:


SQL99標(biāo)準(zhǔn)寫法:

SELECT p.player_name, p.height, h.height_level
FROM player as p JOIN height_grades as h
ON height BETWEEN h.height_lowest AND h.height_highest;

結(jié)果:

自連接

也是內(nèi)連接的一種熟菲,但是「自己」連接「自己」。
比如朴恳,查詢 NBA 數(shù)據(jù)表中身高大于「布雷克-格里芬」的記錄抄罕。
查詢語句:

SELECT b.player_name, b.height 
FROM player as a , player as b 
WHERE a.player_name = '布雷克-格里芬' and a.height < b.height;

結(jié)果:

查詢語句:

SELECT b.player_name, b.height 
FROM player as a JOIN player as b ON a.player_name = '布雷克-格里芬' and a.height < b.height;

USING 連接

查詢語句:

SELECT player_id, team_id, player_name, height, team_name 
FROM player JOIN team USING(team_id);

ON 連接

查詢語句:

SELECT player_id, player.team_id, player_name, height, team_name 
FROM player JOIN team ON player.team_id = team.team_id;

結(jié)果:


外連接(OUTTER JOIN)

左連接

左連接是日常應(yīng)用最廣泛的,右連接較為少見于颖。
查詢語句:

SELECT * 
FROM player 
LEFT JOIN team on player.team_id = team.team_id;

結(jié)果:


右連接

查詢語句:

SELECT * 
FROM player 
RIGHT JOIN  team on player.team_id = team.team_id;

結(jié)果:


全外連接

FULL JOIN

全外連接的結(jié)果 = 左右表匹配的數(shù)據(jù) + 左表沒有匹配到的數(shù)據(jù) + 右表沒有匹配到的數(shù)據(jù)

查詢語句:

SELECT * FROM player FULL JOIN team ON player.team_id = team.team_id

結(jié)果:

(這句報錯了贞绵,待解決)

Ref:

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市恍飘,隨后出現(xiàn)的幾起案子榨崩,更是在濱河造成了極大的恐慌,老刑警劉巖章母,帶你破解...
    沈念sama閱讀 218,525評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件母蛛,死亡現(xiàn)場離奇詭異,居然都是意外死亡乳怎,警方通過查閱死者的電腦和手機(jī)彩郊,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,203評論 3 395
  • 文/潘曉璐 我一進(jìn)店門前弯,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人秫逝,你說我怎么就攤上這事恕出。” “怎么了违帆?”我有些...
    開封第一講書人閱讀 164,862評論 0 354
  • 文/不壞的土叔 我叫張陵浙巫,是天一觀的道長。 經(jīng)常有香客問我刷后,道長的畴,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,728評論 1 294
  • 正文 為了忘掉前任尝胆,我火速辦了婚禮丧裁,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘含衔。我一直安慰自己煎娇,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,743評論 6 392
  • 文/花漫 我一把揭開白布贪染。 她就那樣靜靜地躺著缓呛,像睡著了一般。 火紅的嫁衣襯著肌膚如雪抑进。 梳的紋絲不亂的頭發(fā)上强经,一...
    開封第一講書人閱讀 51,590評論 1 305
  • 那天睡陪,我揣著相機(jī)與錄音寺渗,去河邊找鬼。 笑死兰迫,一個胖子當(dāng)著我的面吹牛信殊,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播汁果,決...
    沈念sama閱讀 40,330評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼涡拘,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了据德?” 一聲冷哼從身側(cè)響起鳄乏,我...
    開封第一講書人閱讀 39,244評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎棘利,沒想到半個月后橱野,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,693評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡善玫,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,885評論 3 336
  • 正文 我和宋清朗相戀三年水援,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,001評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡蜗元,死狀恐怖或渤,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情奕扣,我是刑警寧澤薪鹦,帶...
    沈念sama閱讀 35,723評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站成畦,受9級特大地震影響距芬,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜循帐,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,343評論 3 330
  • 文/蒙蒙 一框仔、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧拄养,春花似錦离斩、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,919評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至棋弥,卻和暖如春核偿,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背顽染。 一陣腳步聲響...
    開封第一講書人閱讀 33,042評論 1 270
  • 我被黑心中介騙來泰國打工漾岳, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人粉寞。 一個月前我還...
    沈念sama閱讀 48,191評論 3 370
  • 正文 我出身青樓尼荆,卻偏偏與公主長得像,于是被迫代替她去往敵國和親唧垦。 傳聞我的和親對象是個殘疾皇子捅儒,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,955評論 2 355

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