亚洲免费在线视频-亚洲啊v-久久免费精品视频-国产精品va-看片地址-成人在线视频网

您的位置:首頁技術文章
文章詳情頁

mysql-joins具體用法說明

瀏覽:119日期:2023-10-05 11:30:01

JOIN對于接觸過數據庫的人,這個詞都不陌生,而且很多人很清楚各種JOIN,還有很多人對這個理解也不是很透徹。假設我們有兩個表,Table_A和Table_B。這兩個表中的數據如下所示:

TABLE_A| TABLE_B PK Value | PK Value---- ---------- | ---- ---------- 1 FOX | 1 TROT 2 COP | 2 CAR 3 TAXI | 3 CAB 6 WASHINGTON | 6 MONUMENT 7 DELL | 7 PC 5 ARIZONA | 8 MICROSOFT 4 LINCOLN | 9 APPLE 10 LUCENT | 11 SCOTCHJoin 語法:

join_table: table_reference JOIN table_factor [join_condition]//內連接 | table_reference {LEFT|RIGHT|FULL} [OUTER] JOIN table_reference join_condition//外連接 | table_reference LEFT SEMI JOIN table_reference join_condition//左半連接 | table_reference CROSS JOIN table_reference [join_condition] (as of Hive 0.10)table_reference: table_factor//表 | join_table//join語句table_factor: tbl_name [alias]//表名[別名] | table_subquery alias//子查尋[別名] | ( table_references )//帶空號的table_referencejoin_condition: ON expression//on開頭的條件語句1、Inner JOIN: (內連接)

mysql-joins具體用法說明

這是最簡單、最容易理解的連接,也是最常見的連接。此查詢將返回左表(表A)中具有右表(表B)中匹配記錄的所有記錄。此連接寫成如下:

SELECT <select_list> FROM Table_A AINNER JOIN Table_B BON A.Key = B.Key

-- Inner JOINSELECT A.PK AS A_PK, A.Value AS A_Value, B.Value AS B_Value, B.PK AS B_PKFROM Table_A AINNER JOIN Table_B BON A.PK = B.PKA_PK A_Value B_Value B_PK---- ---------- ---------- ---- 1 FOX TROT 1 2 COP CAR 2 3 TAXI CAB 3 6 WASHINGTON MONUMENT 6 7 DELL PC 7(5 row(s) affected)2、Left JOIN: (左連接)

mysql-joins具體用法說明

此查詢將返回左表(表A)中的所有記錄,而不管這些記錄是否與右表(表B)中的任何記錄匹配。它還將從正確的表中返回任何匹配的記錄。此連接寫成如下:

SELECT <select_list>FROM Table_A ALEFT JOIN Table_B BON A.Key = B.Key

-- Left JOINSELECT A.PK AS A_PK, A.Value AS A_Value,B.Value AS B_Value, B.PK AS B_PKFROM Table_A ALEFT JOIN Table_B BON A.PK = B.PKA_PK A_Value B_Value B_PK---- ---------- ---------- ---- 1 FOX TROT 1 2 COP CAR 2 3 TAXI CAB 3 4 LINCOLN NULL NULL 5 ARIZONA NULL NULL 6 WASHINGTON MONUMENT 6 7 DELL PC 7 10 LUCENT NULL NULL(8 row(s) affected)3、Left Excluding JOIN: (左連接排除內連接結果)

此查詢將返回左表(表A)中與右表(表B)中的任何記錄都不匹配的所有記錄。此連接寫成如下:

mysql-joins具體用法說明

SELECT <select_list> FROM Table_A ALEFT JOIN Table_B BON A.Key = B.KeyWHERE B.Key IS NULL

-- Left Excluding JOINSELECT A.PK AS A_PK, A.Value AS A_Value,B.Value AS B_Value, B.PK AS B_PKFROM Table_A ALEFT JOIN Table_B BON A.PK = B.PKWHERE B.PK IS NULLA_PK A_Value B_Value B_PK---- ---------- ---------- ---- 4 LINCOLN NULL NULL 5 ARIZONA NULL NULL 10 LUCENT NULL NULL(3 row(s) affected)4、Right JOIN: (右連接)

mysql-joins具體用法說明

此查詢將返回右表(表B)中的所有記錄,而不管這些記錄中是否有任何記錄與左表(表A)中的記錄相匹配。它還將返回左表中的任何匹配記錄。此連接寫成如下:

SELECT <select_list>FROM Table_A ARIGHT JOIN Table_B BON A.Key = B.Key

-- Right JOINSELECT A.PK AS A_PK, A.Value AS A_Value,B.Value AS B_Value, B.PK AS B_PKFROM Table_A ARIGHT JOIN Table_B BON A.PK = B.PKA_PK A_Value B_Value B_PK---- ---------- ---------- ---- 1 FOX TROT 1 2 COP CAR 2 3 TAXI CAB 3 6 WASHINGTON MONUMENT 6 7 DELL PC 7NULL NULL MICROSOFT 8NULL NULL APPLE 9NULL NULL SCOTCH 11(8 row(s) affected)5、Right Excluding JOIN: (右連接排除內連接結果)

mysql-joins具體用法說明

此查詢將返回右表(表B)中與左表(表A)中的任何記錄都不匹配的所有記錄。此連接寫成如下:

SELECT <select_list>FROM Table_A ARIGHT JOIN Table_B BON A.Key = B.KeyWHERE A.Key IS NULL

-- Right Excluding JOINSELECT A.PK AS A_PK, A.Value AS A_Value,B.Value AS B_Value, B.PK AS B_PKFROM Table_A ARIGHT JOIN Table_B BON A.PK = B.PKWHERE A.PK IS NULLA_PK A_Value B_Value B_PK---- ---------- ---------- ----NULL NULL MICROSOFT 8NULL NULL APPLE 9NULL NULL SCOTCH 11(3 row(s) affected)6、Outer JOIN: (外連接)

mysql-joins具體用法說明

此聯接也可以稱為完全外聯接或完全聯接。此查詢將返回兩個表中的所有記錄,連接左表(表A)中與右表(表B)中的記錄相匹配的記錄。此連接寫成如下:

SELECT <select_list>FROM Table_A AFULL OUTER JOIN Table_B BON A.Key = B.Key

-- Outer JOINSELECT A.PK AS A_PK, A.Value AS A_Value,B.Value AS B_Value, B.PK AS B_PKFROM Table_A AFULL OUTER JOIN Table_B BON A.PK = B.PKA_PK A_Value B_Value B_PK---- ---------- ---------- ---- 1 FOX TROT 1 2 COP CAR 2 3 TAXI CAB 3 6 WASHINGTON MONUMENT 6 7 DELL PC 7NULL NULL MICROSOFT 8NULL NULL APPLE 9NULL NULL SCOTCH 11 5 ARIZONA NULL NULL 4 LINCOLN NULL NULL 10 LUCENT NULL NULL(11 row(s) affected)7、Outer Excluding JOIN: (外連接排除內連接結果)

mysql-joins具體用法說明

此查詢將返回左表(表A)中的所有記錄和右表(表B)中不匹配的所有記錄。我還不需要使用這種類型的聯接,但所有其他類型的聯接我都相當頻繁地使用。此連接寫成如下:

SELECT <select_list>FROM Table_A AFULL OUTER JOIN Table_B BON A.Key = B.KeyWHERE A.Key IS NULL OR B.Key IS NULL

-- Outer Excluding JOINSELECT A.PK AS A_PK, A.Value AS A_Value,B.Value AS B_Value, B.PK AS B_PKFROM Table_A AFULL OUTER JOIN Table_B BON A.PK = B.PKWHERE A.PK IS NULLOR B.PK IS NULLA_PK A_Value B_Value B_PK---- ---------- ---------- ----NULL NULL MICROSOFT 8NULL NULL APPLE 9NULL NULL SCOTCH 11 5 ARIZONA NULL NULL 4 LINCOLN NULL NULL 10 LUCENT NULL NULL(6 row(s) affected)

注意,在外部聯接上,首先返回內部連接記錄,然后返回右連接記錄,最后返回左連接記錄(至少,我的Microsoft SQL Server就是這樣做的;當然,這不需要使用任何ORDERBY語句)。您可以訪問維基百科文章以獲得更多信息(但是,條目不是圖形化的)。我還創建了一個備忘單,您可以在需要時打印出來。如果您右鍵單擊下面的圖像并選擇“將目標保存為.”,您將下載完整大小的圖像。

mysql-joins具體用法說明

到此這篇關于mysql-joins具體用法說明的文章就介紹到這了,更多相關mysql-joins用法內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: MySQL 數據庫
相關文章:
主站蜘蛛池模板: 亚洲午夜精品在线 | 美女在线看永久免费网址 | 在线亚洲精品国产波多野结衣 | 怡红院免费的全部视频 | 国产欧美一区二区精品久久久 | 欧美日韩精品在线播放 | 久久女同互慰一区二区三区 | 日韩字幕一中文在线综合 | 亚洲最大情网站在线观看 | 九九香蕉 | 亚洲综合区 | 色偷偷88欧美精品久久久 | 国产三级视频在线播放 | 欧美日本综合一区二区三区 | 欧美精品束缚一区二区三区 | 久久这里有精品视频 | 91久久线看在观草草青青 | 亚洲综合一区二区精品久久 | 国产九九免费视频网站 | 我要看一级大片 | 各种偷拍盗摄视频在线观看 | 亚洲视频中文字幕 | 亚洲人成一区二区三区 | 日韩国产在线 | 成人看的午夜免费毛片 | 欧美日韩乱国产 | 久久久日韩精品国产成人 | 精品国产一区二区二三区在线观看 | 免费一级特黄3大片视频 | 美女视频永久黄网站在线观看 | 高清一区二区 | 欧美在线香蕉在线现视频 | 亚洲另类激情综合偷自拍 | 亚洲免费久久 | 一级全免费视频播放 | 日韩一区二区三区视频在线观看 | 免费久草视频 | 亚洲欧美日韩国产精品一区 | 一区二区中文字幕亚洲精品 | 久久无码av三级 | 国产成人a毛片在线 |