工具/材料:Management Studio。
成都創(chuàng)新互聯(lián)公司自2013年起,先為常德等服務(wù)建站,常德等地企業(yè),進(jìn)行企業(yè)商務(wù)咨詢服務(wù)。為常德企業(yè)網(wǎng)站制作PC+手機(jī)+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問題。
1、首先在桌面上,點(diǎn)擊“Management Studio”圖標(biāo)。
2、之后在該界面中,點(diǎn)擊左上角“新建查詢”選項(xiàng)。
3、接著在該界面中,輸入將兩個(gè)表合在一起的sql語句“select * from test1,test2;”。
4、然后在該界面中,點(diǎn)擊工具欄里的“運(yùn)行三角形”圖標(biāo)。
5、最后在該界面中,顯示成功將兩個(gè)表合在一起。
在日?;跀?shù)據(jù)庫應(yīng)用的開發(fā)過程中,我們經(jīng)常需要對多個(gè)表或者數(shù)據(jù)源進(jìn)行關(guān)聯(lián)查詢而得出我們需要的結(jié)果集。那么Oracle到底存在著哪幾種連接方式?優(yōu)化器內(nèi)部又是怎樣處理這些連接的?哪種連接方式又是適合哪種查詢需求的?只有對這些問題有了清晰的理解后,我們才能針對特定的查詢需求選擇合適的連接方式,開發(fā)出健壯的數(shù)據(jù)庫應(yīng)用程序。選擇合適的表連接方法對SQL語句運(yùn)行的性能有著至關(guān)重要的影響。下面我們就Oracle常用的一些連接方法及適用情景做一個(gè)簡單的介紹。\x0d\x0a3.1嵌套循環(huán)連接(nestedloop)\x0d\x0a嵌套循環(huán)連接的工作方式是這樣的:\x0d\x0a1、Oracle首先選擇一張表作為連接的驅(qū)動(dòng)表,這張表也稱為外部表(OuterTable)。由驅(qū)動(dòng)表進(jìn)行驅(qū)動(dòng)連接的表或數(shù)據(jù)源稱為內(nèi)部表(InnerTable)。\x0d\x0a2、提取驅(qū)動(dòng)表中符合條件的記錄,與被驅(qū)動(dòng)表的連接列進(jìn)行關(guān)聯(lián)查詢符合條件的記錄。在這個(gè)過程中,Oracle首先提取驅(qū)動(dòng)表中符合條件的第一條記錄,再與內(nèi)部表的連接列進(jìn)行關(guān)聯(lián)查詢相應(yīng)的記錄行。在關(guān)聯(lián)查詢的過程中,Oracle會(huì)持續(xù)提取驅(qū)動(dòng)表中其他符合條件的記錄與內(nèi)部表關(guān)聯(lián)查詢。這兩個(gè)過程是并行進(jìn)行的,因此嵌套循環(huán)連接返回前幾條記錄的速度是非??斓摹T谶@里需要說明的是,由于Oracle最小的IO單位為單個(gè)數(shù)據(jù)塊,因此在這個(gè)過程中Oracle會(huì)首先提取驅(qū)動(dòng)表中符合條件的單個(gè)數(shù)據(jù)塊中的所有行,再與內(nèi)部表進(jìn)行關(guān)聯(lián)連接查詢的,然后提取下一個(gè)數(shù)據(jù)塊中的記錄持續(xù)地循環(huán)連接下去。當(dāng)然,如果單行記錄跨越多個(gè)數(shù)據(jù)塊的話,就是一次單條記錄進(jìn)行關(guān)聯(lián)查詢的。\x0d\x0a3、嵌套循環(huán)連接的過程如下所示:\x0d\x0aNestedloop\x0d\x0aOuterloop\x0d\x0aInnerloop\x0d\x0a我們可以看出這里面存在著兩個(gè)循環(huán),一個(gè)是外部循環(huán),提取驅(qū)動(dòng)表中符合條件的每條記錄。另外一個(gè)是內(nèi)部循環(huán),根據(jù)外循環(huán)中提取的每條記錄對內(nèi)部表進(jìn)行連接查詢相應(yīng)的記錄。由于這兩個(gè)循環(huán)是嵌套進(jìn)行的,故此種連接方法稱為嵌套循環(huán)連接。\x0d\x0a嵌套循環(huán)連接適用于查詢的選擇性強(qiáng)、約束性高并且僅返回小部分記錄的結(jié)果集。通常要求驅(qū)動(dòng)表的記錄(符合條件的記錄,通常通過高效的索引訪問)較少,且被驅(qū)動(dòng)表連接列有唯一索引或者選擇性強(qiáng)的非唯一索引時(shí),嵌套循環(huán)連接的效率是比較高的。\x0d\x0a嵌套循環(huán)連接驅(qū)動(dòng)表的選擇也是連接中需要著重注意的一點(diǎn),有一個(gè)常見的誤區(qū)是驅(qū)動(dòng)表要選擇小表,其實(shí)這是不對的。假如有兩張表A、B關(guān)聯(lián)查詢,A表有1000000條記錄,B表有10000條記錄,但是A表過濾出來的記錄只有10條,這時(shí)候顯然用A表當(dāng)做驅(qū)動(dòng)表是比較合適的。因此驅(qū)動(dòng)表是由過濾條件限制返回記錄最少的那張表,而不是根據(jù)表的大小來選擇的。\x0d\x0a在外連接查詢中,如果走嵌套循環(huán)連接的話,那么驅(qū)動(dòng)表必然是沒有符合條件關(guān)聯(lián)的那張表,也就是后面不加(+)的那張表。這是由于外連接需要提取可能另一張表沒符合條件的記錄,因此驅(qū)動(dòng)表需要是那張我們要返回所有符合條件記錄的表。比如下面這個(gè)查詢,\x0d\x0a嵌套循環(huán)連接返回前幾行的記錄是非??斓?,這是因?yàn)槭褂昧饲短籽h(huán)后,不需要等到全部循環(huán)結(jié)束再返回結(jié)果集,而是不斷地將查詢出來的結(jié)果集返回。在這種情況下,終端用戶將會(huì)快速地得到返回的首批記錄,且同時(shí)等待Oracle內(nèi)部處理其他記錄并返回。如果查詢的驅(qū)動(dòng)表的記錄數(shù)非常多,或者被驅(qū)動(dòng)表的連接列上無索引或索引不是高度可選的情況,嵌套循環(huán)連接的效率是非常低的\x0d\x0a--刪除原表\x0d\x0adroptablet1;\x0d\x0a\x0d\x0a--建立測試表\x0d\x0acreatetablet1(\x0d\x0af1varchar2(10),\x0d\x0af2varchar2(1000)\x0d\x0a)\x0d\x0atablespaceCTL\x0d\x0apctfree98;\x0d\x0a\x0d\x0a--填充測試內(nèi)容\x0d\x0ainsertintot1(f1,f2)\x0d\x0aselectrownum,lpad(rownum,700,'0')\x0d\x0afromdba_tablesa,dba_tab_colsb\x0d\x0awherea.owner=b.owner\x0d\x0aandrownumselect/*+ordereduse_hash(t1,t2)*/\x0d\x0at1.f1,t2.f1\x0d\x0afromctl.t1t1,ctl.t2t2\x0d\x0awheret1.f1=t2.f1234;\x0d\x0a\x0d\x0a999rowsselected.\x0d\x0a\x0d\x0aExecutionPlan\x0d\x0a----------------------------------------------------------\x0d\x0a0SELECTSTATEMENTOptimizer=CHOOSE(Cost=5Card=82Bytes=1148\x0d\x0a)\x0d\x0a10HASHJOIN(Cost=5Card=82Bytes=1148)\x0d\x0a21TABLEACCESS(FULL)OF'T1'(Cost=2Card=82Bytes=574)\x0d\x0a31TABLEACCESS(FULL)OF'T2'(Cost=2Card=82Bytes=574)\x0d\x0a\x0d\x0aStatistics\x0d\x0a----------------------------------------------------------\x0d\x0a0recursivecalls\x0d\x0a0dbblockgets\x0d\x0a11113consistentgets\x0d\x0a0physicalreads\x0d\x0a0redosize\x0d\x0a23590bytessentviaSQL*Nettoclient\x0d\x0a1381bytesreceivedviaSQL*Netfromclient\x0d\x0a68SQL*Netroundtripsto/fromclient\x0d\x0a0sorts(memory)\x0d\x0a0sorts(disk)\x0d\x0a999rowsprocessed\x0d\x0a3.3,排序合并連接(mergejoin)\x0d\x0a排序合并連接的方法非常簡單。在排序合并連接中是沒有驅(qū)動(dòng)表的概念的,兩個(gè)互相連接的表按連接列的值先排序,排序完后形成的結(jié)果集再互相進(jìn)行合并連接提取符合條件的記錄。相比嵌套循環(huán)連接,排序合并連接比較適用于返回大數(shù)據(jù)量的結(jié)果。\x0d\x0a排序合并連接在數(shù)據(jù)表預(yù)先排序好的情況下效率是非常高的,也比較適用于非等值連接的情況,比如、=、=)\x0d\x0a3,hash_join_enabled=false;\x0d\x0a4,數(shù)據(jù)源已排序
1、在使用where進(jìn)行查詢的時(shí)候,對于查詢條件中的字段要指定歸屬表或者表別名。如下圖。
2、如果改為using進(jìn)行查詢的話那就不用指定表別名,using關(guān)鍵字的使用規(guī)則就是等值連接而且連接的字段名稱和字段類型必須要一致。
3、如果在使用了using關(guān)鍵字進(jìn)行查詢的時(shí)候如果添加了表的別名或者是表名,則直接會(huì)報(bào)如下錯(cuò)誤,對于using關(guān)鍵字指定的列名 在查詢中是不能使用表名或者表別名的。
4、并且還有一點(diǎn)需要注意的是using后只能接字段名不能使用 大于? 等于? 小于等符號(hào)進(jìn)行比對。
select e.empno, e.ename, d.deptno, d.dname
from emp e, dept d
where e.deptno = d.deptno;
在之前所使用的查詢操作之中,都是從一張表之中查詢出所需要的內(nèi)容,那么如果現(xiàn)在一個(gè)查詢語句需要顯示多張表的數(shù)據(jù),則就必須應(yīng)用到多表查詢的操作,而多表查詢的語法如下:
SELECT [DISTINCT] * | 字段 [別名] [,字段 [別名] ,…] FROM 表名稱 [別名], [表名稱 [別名] ,…] [WHERE 條件(S)] [ORDER BY 排序字段 [ASC|DESC] [,排序字段 [ASC|DESC] ,…]]。
擴(kuò)展資料:
Oracle 常用的關(guān)聯(lián)查詢:
Oracle外連接:
(1)左外連接 (左邊的表不加限制)。
(2)右外連接(右邊的表不加限制)。
(3)全外連接(左右兩表都不加限制)。
outer join則會(huì)返回每個(gè)滿足第一個(gè)(頂端)輸入與第二個(gè)(底端)輸入的聯(lián)接的行。它還返回任何在第二個(gè)輸入中沒有匹配行的第一個(gè)輸入中的行。
外連接分為三種: 左外連接,右外連接,全外連接。 對應(yīng)SQL:LEFT/RIGHT/FULL OUTER JOIN。 通常我們省略outer 這個(gè)關(guān)鍵字。 寫成:LEFT/RIGHT/FULL JOIN。
在左外連接和右外連接時(shí)都會(huì)以一張表為基表,該表的內(nèi)容會(huì)全部顯示,然后加上兩張表匹配的內(nèi)容。 如果基表的數(shù)據(jù)在另一張表沒有記錄。 那么在相關(guān)聯(lián)的結(jié)果集行中列顯示為空值(NULL)。
以兩表為例:
有以下兩張表:
現(xiàn)在要通過deptno字段,在查詢中顯示emp表中全部內(nèi)容和dept表中的dname字段。
可用如下語句:
select?a.*,b.dname?from?emp?a,dept?b?where?a.deptno=b.deptno;
查詢結(jié)果:
網(wǎng)站題目:oracle怎么多表連接 oracle 多表連接
標(biāo)題網(wǎng)址:http://www.rwnh.cn/article8/hhgeop.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供定制開發(fā)、網(wǎng)站設(shè)計(jì)、網(wǎng)站維護(hù)、標(biāo)簽優(yōu)化、自適應(yīng)網(wǎng)站、網(wǎng)頁設(shè)計(jì)公司
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)