麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 數據庫 > MySQL > 正文

mysql多表連接查詢實例講解

2024-07-25 19:09:05
字體:
來源:轉載
供稿:網友

實際的項目,存在多張表的關聯關系。不可能在一張表里面就能檢索出所有數據。如果沒有表連接的話,那么我們就需要非常多的操作。比如需要從A表找出限制性的條件來從B表中檢索數據。不但需要分多表來操作,而且效率也不高。比如書中的例子:

代碼如下:

SELECT FIdFROM T_CustomerWHERE FName='MIKE'

這個SQL語句返回2,也就是姓名為MIKE 的客戶的FId值為2,這樣就可以到T_Order中檢索FCustomerId等于2 的記錄:

代碼如下:

SELECT FNumber,FPriceFROM T_OrderWHERE FCustomerId=2

下面我們詳細來看看表連接。表連接有多種不同的類型,有交叉連接(CROSS JOIN)、內連接(INNER JOIN)、外連接(OUTTER JOIN)。

(1)內連接(INNER JOIN):內連接組合兩張表,并且只獲取滿足兩表連接條件的數據。

代碼如下:

SELECT o.FId,o.FNumber,o.FPrice,c.FId,c.FName,c .FAgeFROM T_Order o JOIN T_Customer cON o.FCustomerId= c.FId

注:在大多數數據庫系統中,INNER JOIN中的INNER是可選的,INNER JOIN 是默認的連接方式。

在使用表連接的時候可以不局限于只連接兩張表,因為有很多情況下需要聯系許多表。例如,T_Order表同時還需要連接T_Customer和T_OrderType兩張表才能檢索到所需要的信息,編寫如下SQL語句即可:

代碼如下:

SELECT o.FId,o.FNumber,o.FPrice,c.FId,c.FName,c .FAgeFROM T_Order o JOIN T_Customer cON o.FCustomerId= c.FIdINNER JOIN T_OrderTypeON T_Order.FTypeId= T_OrderType.FId

(2)交叉連接(CROSS JOIN):交叉連接所有涉及的表中的所有記錄都包含在結果集中。可以采用兩種方式來定義交叉連接,分別是隱式和顯式的連接。

下面看看隱式的例子:

代碼如下:

SELECT T_Customer.FId, T_Customer.FName, T_Customer.FAge,T_Order.FId, T_Order.FNumber, T_Order.FPriceFROM T_Customer, T_Order

使用顯式的連接則需要使用CROSS JOIN,例子如下:

代碼如下:

SELECT T_Customer.FId, T_Customer.FName, T_Customer.FAge,T_Order.FId, T_Order.FNumber, T_Order.FPriceFROM T_CustomerCROSS JOIN T_Order

(3)外連接(OUTTER JOIN):內部連接只獲取滿足連接條件的數據,而對于外部連接來說,主要是解決這樣的一種場景。滿足條件的數據檢索出來,這個沒有疑問,外部連接還會檢索另一部分數據,那就是將不滿足條件的數據以NULL來填充。先來看一下外連接的分類:左外部連接(LEFT OUTER JOIN)、右外部連接(RIGHT OUTER JOIN)和全外部連接(FULLOUTER JOIN)。

I、左外部連接(LEFT OUTER JOIN):前頭也說了,將不滿足條件的數據以NULL來填充。那么具體是哪些需要以NULL來填充呢,對于左外連接來說的話,連接條件當中,如果出現滿足條件的左表的數據在右表中沒有相應匹配時,需要把相應的右表字段填充NULL值。也就是說左外部連接的主體是左表,右表來配合。

代碼如下:

SELECT o.FNumber,o.FPrice,o.FCustomerId,c.FName,c.FAgeFROM T_Order oLEFT OUTER JOIN T_Customer cON o.FCustomerId=c.FId

注:如果使用左外部連接的話,通過where語句能過濾其中不符合的數據

代碼如下:

SELECT o.FNumber,o.FPrice,o.FCustomerId,c.FName,c.FAgeFROM T_Order oLEFT OUTER JOIN T_Customer cON o.FCustomerId=c.FIdWHERE o.FPrice>=150

II、右外部連接(RIGHT OUTER JOIN):右外部連接與左外連部接相反,將會被填充NULL值的是左表的字段。也就是說右外部連接的主體是右表,左表來配合。

代碼如下:

SELECT o.FNumber,o.FPrice,o.FCustomerId,c.FName,c.FAgeFROM T_Order oRIGHT OUTER JOIN T_Customer cON o.FCustomerId=c.FId

注:同左外連接一樣,可以使用where語句進行過濾

III、全外部連接(FULLOUTER JOIN):全外部連接是左外部連接和右外部連接的合集。也就是既包括左外部連接的結果集,也包括右外部連接的結果集。

代碼如下:

SELECT o.FNumber,o.FPrice,o.FCustomerId,c.FName,c.FAgeFROM T_Order oFULL OUTER JOIN T_Customer cON o.FCustomerId=c.FId

其結果相當于:

SELECT o.FNumber,o.FPrice,o.FCustomerId,c.FName,c.FAgeFROM T_Order oLEFT OUTER JOIN T_Customer cON o.FCustomerId=c.FIdUNIONSELECT o.FNumber,o.FPrice,o.FCustomerId,c.FName,c.FAgeFROM T_Order oRIGHT OUTER JOIN T_Customer cON o.FCustomerId=c.FId

多表查詢的多種sql寫法:(下面是從兩個表里查詢<也可以看成從三個表里查詢>,顯示表v_goods里的所有字段,顯示admin2表里的name字段作為添加人,顯示表admin2表的name字段作為操作人) 多個表的查詢都可按照下面三個例句進行編寫sql

SELECT v.*,(SELECT a.name FROM admin2 a WHERE a.adminId=v.loadInId) AS aname,(SELECT a.name FROM admin2 a WHERE a.adminId=v.operatorId) AS uname FROM v_goods v where 1=1;SELECT v.*,a.name aname,b.name uname FROM v_goods v,admin2 a,admin2 b WHERE a.adminId=v.loadInId AND b.adminId=v.operatorId ;SELECT v.*,a.name aname,b.name uname FROM v_goods v LEFT JOIN admin2 a ON a.adminId=v.loadInId LE


注:相關教程知識閱讀請移步到MYSQL教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 亚洲成a| 久久综合给合久久狠狠狠97色69 | 久草手机在线视频 | 欧美日韩在线视频一区二区 | 男人的天堂色偷偷 | 日本成年免费网站 | 色中色在线播放 | 视频一区二区三区在线播放 | 密室逃脱第一季免费观看完整在线 | 免费网址黄| 欧美 国产 综合 | 少妇一级淫片免费放正片 | 在线播放免费人成毛片乱码 | 99国产精品白浆在线观看免费 | 斗罗破苍穹在线观看免费完整观看 | 暴力强行进如hdxxx | h网站在线观看 | 日韩大片在线永久观看视频网站免费 | 精品一区二区三区免费 | 精品一区二区三区日本 | 欧美毛片 | a级黄色片视频 | 欧美黄色一区 | 国产成人精品一区二区仙踪林 | 大号bbwassbigav头交 | 插插操 | 一级毛片免费在线 | 国产精品午夜在线 | 国产精品视频二区不卡 | 欧美1区2区在线观看 | 狠狠干天天操 | 国产一级毛片高清视频完整版 | 免费在线观看国产精品 | 国产91精品欧美 | 久久久久久亚洲综合影院红桃 | 欧美大荫蒂xxx | 亚洲情视频 | 欧美城网站地址 | 久久不射电影 | 亚洲精品有限 | 天天黄色片 |