a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁(yè) > 數(shù)據(jù)庫(kù) > 文庫(kù) > 正文

SQL多表查詢(xún)合并至單一聲明的常用方式

2024-09-07 22:12:21
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

  在對(duì)跨多個(gè)表格的數(shù)據(jù)進(jìn)行組合時(shí),有時(shí)很難搞清楚要使用哪一個(gè)SQL句法。我將在這里對(duì)將多個(gè)表格中的查詢(xún)合并至單一聲明中的常用方式進(jìn)行闡述。

  在這篇文章中的樣本查詢(xún)符合SQL92 ISO標(biāo)準(zhǔn)。不是所有的數(shù)據(jù)庫(kù)生產(chǎn)商都遵循這項(xiàng)標(biāo)準(zhǔn),而且很多廠商采取的提升措施會(huì)帶來(lái)一些意料不到的后果。如果你不確定你的數(shù)據(jù)庫(kù)是不是支持這些標(biāo)準(zhǔn),你可以參看生產(chǎn)廠商的有關(guān)資料。

  SELECT

  一個(gè)簡(jiǎn)單的SELECT聲明就是查詢(xún)多個(gè)表格的最基本的方式。你可以在FROM子句中調(diào)用多個(gè)表格來(lái)組合來(lái)自多個(gè)表格的結(jié)果。這里是一個(gè)它如何工作的實(shí)例:

 

以下是引用片段:
  SELECT table1.column1, table2.column2 FROM table1,
  table2 WHERE table1.column1 = table2.column1;

  這個(gè)實(shí)例中,我使用點(diǎn)號(hào)(table1.column1)來(lái)指定專(zhuān)欄來(lái)自哪一個(gè)表格。如果所涉及的專(zhuān)欄只在一個(gè)參考的表格中出現(xiàn),你就不需要加入完整的名稱(chēng),但是加入完整名稱(chēng)會(huì)對(duì)可讀性起到幫助。

  在FROM子句中表格之間由逗號(hào)來(lái)分隔,你可以加入所需的任意多的表格,盡管一些數(shù)據(jù)庫(kù)有一個(gè)在引入正式的JOIN聲明之前他們可以有效地處理的內(nèi)容這方面的限制,這個(gè)將在下面談到。

  這個(gè)句法是一個(gè)簡(jiǎn)單的INNER JOIN。一些數(shù)據(jù)庫(kù)將它看成與一個(gè)外部的JOIN是等同的。WHERE子句告知數(shù)據(jù)庫(kù)哪一個(gè)區(qū)域要做關(guān)聯(lián),而且它返回結(jié)果時(shí),就像列出的表格在給定的條件下組合成一個(gè)單獨(dú)的表格一樣。值得注意的是,你的比較條件并不需要與你作為結(jié)果組返回的專(zhuān)欄相同。在上面的例子中,table1.column1和table2.column1用來(lái)組合表格,但是返回的卻是table2.column2。

  你可以在WHERE子句中使用AND關(guān)鍵字來(lái)將這個(gè)功能擴(kuò)展至多于兩個(gè)的表格。你還可以使用這樣的表格組合來(lái)限制你的結(jié)果而不用實(shí)際地從每個(gè)表格返回專(zhuān)欄。在下面的例子中,table3與table1匹配,但是我沒(méi)有從table3返回任何東西來(lái)顯示。我只是確保來(lái)自table1的有關(guān)專(zhuān)欄存在于table3之中。注意此例中table3需要在FROM子句中被引用。

 

以下是引用片段:
  SELECT table1.column1, table2.column2 FROM table1,
  table2, table3 WHERE table1.column1 =
  table2.column1 AND table1.column1 = table3.column1;

  然而,要注意的是,這個(gè)查詢(xún)多個(gè)表格的方式是一個(gè)暗指的JOIN。你的數(shù)據(jù)庫(kù)可能對(duì)事物進(jìn)行不同的處理,這取決于它所使用的優(yōu)化引擎。而且,忽略對(duì)與WHERE子句的相關(guān)特性的定義將會(huì)給你帶來(lái)不愿看到的結(jié)果,例如從余下的查詢(xún)中返回與每一個(gè)可能的結(jié)果相關(guān)的專(zhuān)欄的rogue域,就像在CROSS JOIN之中一樣。

  如果你習(xí)慣于你的數(shù)據(jù)庫(kù)處理這種類(lèi)型的聲明的方式,且你只對(duì)兩個(gè)或是少數(shù)幾個(gè)表格進(jìn)行組合,一個(gè)簡(jiǎn)單的SELECT聲明就可以達(dá)到目的。

  JOIN

  JOIN的工作方式與SELECT聲明是相同的,它從不同的表格中返回一個(gè)帶有專(zhuān)欄的結(jié)果組。在暗含的JOIN之上使用外部JOIN的優(yōu)勢(shì)是對(duì)你的結(jié)果組的更好的控制,而且還可能在涉及很多個(gè)表格的情況下提升性能表現(xiàn)。

  JOIN的類(lèi)型有幾種:LEFT,RIGHT,F(xiàn)ULL OUTER,INNER和CROSS。你所使用的類(lèi)型是由你想要看到的結(jié)果所決定的。例如,使用LEFT OUTER JOIN將會(huì)從列出的第一個(gè)表格中返回所有有關(guān)的行,而同時(shí)如果沒(méi)有信息與第一個(gè)表格相關(guān)的話將潛在地從所列出的第二個(gè)表格中加入行。

  在這里INNER JOIN和暗含的JOIN是不同的,INNER JOIN將只返回那些在兩個(gè)表格中都有數(shù)據(jù)的行。

  對(duì)第一個(gè)SELECT查詢(xún)使用如下JOIN聲明:

 

以下是引用片段:
  SELECT table1.column1, table2.column2 FROM table1 INNER JOIN table2
  ON table1.column1 = table2.column1;

  子查詢(xún)

  子查詢(xún),或叫子選擇聲明,是在一個(gè)查詢(xún)中將結(jié)果組作為資源使用的一個(gè)途徑。他經(jīng)常被用來(lái)對(duì)結(jié)果進(jìn)行限制或定義,而不是運(yùn)行多個(gè)查詢(xún)或操縱應(yīng)用軟件之中的數(shù)據(jù)。有了子查詢(xún),你可以參考表格來(lái)決定數(shù)據(jù)的內(nèi)含,或是在一些情況下,返回一個(gè)專(zhuān)欄,而這個(gè)專(zhuān)欄是一個(gè)子選擇的結(jié)果。

  下面的例子中使用了兩個(gè)表格。一個(gè)表格中包含了我想要返回的數(shù)據(jù),而另一個(gè)表格則給出一個(gè)比較點(diǎn)來(lái)確定什么數(shù)據(jù)是我確實(shí)感興趣的。

 

以下是引用片段:
  SELECT column1 FROM table1 WHERE EXISTS
  ( SELECT column1 FROM table2
  WHERE table1.column1 = table2.column1 );

  子查詢(xún)很重要的一個(gè)方面就是性能表現(xiàn)。便利性是有代價(jià)的,它取決于你所使用的表格和聲明的大小,數(shù)量和復(fù)雜性,還有你可能會(huì)允許你的應(yīng)用軟件做處理工作。每一個(gè)查詢(xún)?cè)诒恢鞑樵?xún)作為資源使用之前,都將被完整地單獨(dú)處理。如果可能的話,創(chuàng)造性地使用JOIN聲明可以以較少的滯后時(shí)間提供出相同的信息。

發(fā)表評(píng)論 共有條評(píng)論
用戶(hù)名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 91麻豆久久久 | 国产精品久久精品 | 中文字幕视频网站 | 99精品国自产在线观看 | 亚洲综合无码一区二区 | 草久久久| 国产视频一区二区 | 国产午夜久久久久 | 操操操日日日 | 荡女妇边被c边呻吟视频 | 亚洲综合无码一区二区 | 久久女同互慰一区二区三区 | 免费黄色福利网站 | 在线免费看a | 福利网站在线观看 | 亚洲天堂色2017 | 91福利电影在线观看 | 黄色av网站大全 | 久久久精彩视频 | 久久99国产一区二区三区 | 中文字幕成人免费视频 | 成人一区二区三区久久精品嫩草 | 国产精品久久久久久久久久久久久久 | 国产亚洲欧美一区二区三区 | 一本视频在线 | 国产精品第一国产精品 | 亚洲网站久久 | 热久久免费视频 | 在线免费观看色视频 | 三级黄视频在线观看 | 香蕉黄色一级片 | 免费的av在线 | 91 在线观看 | 国产精品一卡二卡三卡 | 国产精品久久久久久久电影 | 欧美一区2区三区3区公司 | 毛片免费在线观看 | 精品国产一区二区三区久久久蜜臀 | 国产在线观看av | 日韩视频一区 | 欧美日韩高清在线一区 |