工具/材料:Management Studio。
成都創(chuàng)新互聯(lián)公司自2013年起,先為常德等服務(wù)建站,常德等地企業(yè),進行企業(yè)商務(wù)咨詢服務(wù)。為常德企業(yè)網(wǎng)站制作PC+手機+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問題。
1、首先在桌面上,點擊“Management Studio”圖標。
2、之后在該界面中,點擊左上角“新建查詢”選項。
3、接著在該界面中,輸入將兩個表合在一起的sql語句“select * from test1,test2;”。
4、然后在該界面中,點擊工具欄里的“運行三角形”圖標。
5、最后在該界面中,顯示成功將兩個表合在一起。
在日常基于數(shù)據(jù)庫應(yīng)用的開發(fā)過程中,我們經(jīng)常需要對多個表或者數(shù)據(jù)源進行關(guān)聯(lián)查詢而得出我們需要的結(jié)果集。那么Oracle到底存在著哪幾種連接方式?優(yōu)化器內(nèi)部又是怎樣處理這些連接的?哪種連接方式又是適合哪種查詢需求的?只有對這些問題有了清晰的理解后,我們才能針對特定的查詢需求選擇合適的連接方式,開發(fā)出健壯的數(shù)據(jù)庫應(yīng)用程序。選擇合適的表連接方法對SQL語句運行的性能有著至關(guān)重要的影響。下面我們就Oracle常用的一些連接方法及適用情景做一個簡單的介紹。\x0d\x0a3.1嵌套循環(huán)連接(nestedloop)\x0d\x0a嵌套循環(huán)連接的工作方式是這樣的:\x0d\x0a1、Oracle首先選擇一張表作為連接的驅(qū)動表,這張表也稱為外部表(OuterTable)。由驅(qū)動表進行驅(qū)動連接的表或數(shù)據(jù)源稱為內(nèi)部表(InnerTable)。\x0d\x0a2、提取驅(qū)動表中符合條件的記錄,與被驅(qū)動表的連接列進行關(guān)聯(lián)查詢符合條件的記錄。在這個過程中,Oracle首先提取驅(qū)動表中符合條件的第一條記錄,再與內(nèi)部表的連接列進行關(guān)聯(lián)查詢相應(yīng)的記錄行。在關(guān)聯(lián)查詢的過程中,Oracle會持續(xù)提取驅(qū)動表中其他符合條件的記錄與內(nèi)部表關(guān)聯(lián)查詢。這兩個過程是并行進行的,因此嵌套循環(huán)連接返回前幾條記錄的速度是非??斓摹T谶@里需要說明的是,由于Oracle最小的IO單位為單個數(shù)據(jù)塊,因此在這個過程中Oracle會首先提取驅(qū)動表中符合條件的單個數(shù)據(jù)塊中的所有行,再與內(nèi)部表進行關(guān)聯(lián)連接查詢的,然后提取下一個數(shù)據(jù)塊中的記錄持續(xù)地循環(huán)連接下去。當然,如果單行記錄跨越多個數(shù)據(jù)塊的話,就是一次單條記錄進行關(guān)聯(lián)查詢的。\x0d\x0a3、嵌套循環(huán)連接的過程如下所示:\x0d\x0aNestedloop\x0d\x0aOuterloop\x0d\x0aInnerloop\x0d\x0a我們可以看出這里面存在著兩個循環(huán),一個是外部循環(huán),提取驅(qū)動表中符合條件的每條記錄。另外一個是內(nèi)部循環(huán),根據(jù)外循環(huán)中提取的每條記錄對內(nèi)部表進行連接查詢相應(yīng)的記錄。由于這兩個循環(huán)是嵌套進行的,故此種連接方法稱為嵌套循環(huán)連接。\x0d\x0a嵌套循環(huán)連接適用于查詢的選擇性強、約束性高并且僅返回小部分記錄的結(jié)果集。通常要求驅(qū)動表的記錄(符合條件的記錄,通常通過高效的索引訪問)較少,且被驅(qū)動表連接列有唯一索引或者選擇性強的非唯一索引時,嵌套循環(huán)連接的效率是比較高的。\x0d\x0a嵌套循環(huán)連接驅(qū)動表的選擇也是連接中需要著重注意的一點,有一個常見的誤區(qū)是驅(qū)動表要選擇小表,其實這是不對的。假如有兩張表A、B關(guān)聯(lián)查詢,A表有1000000條記錄,B表有10000條記錄,但是A表過濾出來的記錄只有10條,這時候顯然用A表當做驅(qū)動表是比較合適的。因此驅(qū)動表是由過濾條件限制返回記錄最少的那張表,而不是根據(jù)表的大小來選擇的。\x0d\x0a在外連接查詢中,如果走嵌套循環(huán)連接的話,那么驅(qū)動表必然是沒有符合條件關(guān)聯(lián)的那張表,也就是后面不加(+)的那張表。這是由于外連接需要提取可能另一張表沒符合條件的記錄,因此驅(qū)動表需要是那張我們要返回所有符合條件記錄的表。比如下面這個查詢,\x0d\x0a嵌套循環(huán)連接返回前幾行的記錄是非??斓?,這是因為使用了嵌套循環(huán)后,不需要等到全部循環(huán)結(jié)束再返回結(jié)果集,而是不斷地將查詢出來的結(jié)果集返回。在這種情況下,終端用戶將會快速地得到返回的首批記錄,且同時等待Oracle內(nèi)部處理其他記錄并返回。如果查詢的驅(qū)動表的記錄數(shù)非常多,或者被驅(qū)動表的連接列上無索引或索引不是高度可選的情況,嵌套循環(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ū)動表的概念的,兩個互相連接的表按連接列的值先排序,排序完后形成的結(jié)果集再互相進行合并連接提取符合條件的記錄。相比嵌套循環(huán)連接,排序合并連接比較適用于返回大數(shù)據(jù)量的結(jié)果。\x0d\x0a排序合并連接在數(shù)據(jù)表預(yù)先排序好的情況下效率是非常高的,也比較適用于非等值連接的情況,比如、=、=)\x0d\x0a3,hash_join_enabled=false;\x0d\x0a4,數(shù)據(jù)源已排序
1、在使用where進行查詢的時候,對于查詢條件中的字段要指定歸屬表或者表別名。如下圖。
2、如果改為using進行查詢的話那就不用指定表別名,using關(guān)鍵字的使用規(guī)則就是等值連接而且連接的字段名稱和字段類型必須要一致。
3、如果在使用了using關(guān)鍵字進行查詢的時候如果添加了表的別名或者是表名,則直接會報如下錯誤,對于using關(guān)鍵字指定的列名 在查詢中是不能使用表名或者表別名的。
4、并且還有一點需要注意的是using后只能接字段名不能使用 大于? 等于? 小于等符號進行比對。
select e.empno, e.ename, d.deptno, d.dname
from emp e, dept d
where e.deptno = d.deptno;
在之前所使用的查詢操作之中,都是從一張表之中查詢出所需要的內(nèi)容,那么如果現(xiàn)在一個查詢語句需要顯示多張表的數(shù)據(jù),則就必須應(yīng)用到多表查詢的操作,而多表查詢的語法如下:
SELECT [DISTINCT] * | 字段 [別名] [,字段 [別名] ,…] FROM 表名稱 [別名], [表名稱 [別名] ,…] [WHERE 條件(S)] [ORDER BY 排序字段 [ASC|DESC] [,排序字段 [ASC|DESC] ,…]]。
擴展資料:
Oracle 常用的關(guān)聯(lián)查詢:
Oracle外連接:
(1)左外連接 (左邊的表不加限制)。
(2)右外連接(右邊的表不加限制)。
(3)全外連接(左右兩表都不加限制)。
outer join則會返回每個滿足第一個(頂端)輸入與第二個(底端)輸入的聯(lián)接的行。它還返回任何在第二個輸入中沒有匹配行的第一個輸入中的行。
外連接分為三種: 左外連接,右外連接,全外連接。 對應(yīng)SQL:LEFT/RIGHT/FULL OUTER JOIN。 通常我們省略outer 這個關(guān)鍵字。 寫成:LEFT/RIGHT/FULL JOIN。
在左外連接和右外連接時都會以一張表為基表,該表的內(nèi)容會全部顯示,然后加上兩張表匹配的內(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é)果: