PL/SQL登錄到數(shù)據(jù)庫,使用tools工具進(jìn)行導(dǎo)入。使用plsql登錄到需要導(dǎo)入數(shù)據(jù)的數(shù)據(jù)庫。點(diǎn)擊工具欄上【tools】--【Import tables】
專注于為中小企業(yè)提供成都網(wǎng)站設(shè)計(jì)、成都做網(wǎng)站服務(wù),電腦端+手機(jī)端+微信端的三站合一,更高效的管理,為中小企業(yè)樂昌免費(fèi)做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動(dòng)了1000多家企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設(shè)實(shí)現(xiàn)規(guī)模擴(kuò)充和轉(zhuǎn)變。
請(qǐng)點(diǎn)擊輸入圖片描述
點(diǎn)擊工具【SQL Inserts】(第二個(gè)選項(xiàng)),點(diǎn)擊選擇需要導(dǎo)入的數(shù)據(jù)庫腳本。
請(qǐng)點(diǎn)擊輸入圖片描述
選擇sql腳本的,點(diǎn)擊打開,即可打開數(shù)據(jù)庫腳本文件,數(shù)據(jù)庫腳本就可以預(yù)加載到plsq工具中。
請(qǐng)點(diǎn)擊輸入圖片描述
開始導(dǎo)入數(shù)據(jù)庫數(shù)據(jù)。選擇完sql腳本之后,點(diǎn)擊【Import】按鈕開始將腳本中的數(shù)據(jù)導(dǎo)入到數(shù)據(jù)庫中,這個(gè)操作執(zhí)行一次即可,如果數(shù)據(jù)量比較大,會(huì)出現(xiàn)卡頓。
請(qǐng)點(diǎn)擊輸入圖片描述
執(zhí)行完之后,沒有任何報(bào)錯(cuò)說明插入成功。【注意:一定記得點(diǎn)擊commit進(jìn)行提交數(shù)據(jù),否則數(shù)據(jù)不會(huì)提交到數(shù)據(jù)庫進(jìn)行存儲(chǔ)】
請(qǐng)點(diǎn)擊輸入圖片描述
查詢驗(yàn)證插入的數(shù)據(jù)。插入完之后,可以編寫sql語句對(duì)插入的數(shù)據(jù)進(jìn)行核對(duì)。執(zhí)行查詢sql看到剛才插入的數(shù)據(jù)。
請(qǐng)點(diǎn)擊輸入圖片描述
Oracle可以使用SQL Plus進(jìn)行執(zhí)行,但是可視化不夠,建議使用另外一個(gè)查詢輔助工具PLSQL Developer,使用PLSQL Developer工具里面各種可視化都很好看出查詢出數(shù)據(jù)的結(jié)果以及可以用這個(gè)工具分析SQL的執(zhí)行分析。
Sql性能非常差的時(shí)候,oracle提供了SQL_TRACE來跟蹤sql的執(zhí)行情況。
注:分析sql的方式比較多,還有根據(jù)優(yōu)化器、sql執(zhí)行計(jì)劃來分析。
SQL_TRACE能夠?qū)ql執(zhí)行的過程輸出到一個(gè)trace文件里面。
首先設(shè)置自己定義的trace文件的標(biāo)識(shí)方便查找。
alter session set tracefile_identifier='mytest';
然后對(duì)當(dāng)前會(huì)話啟動(dòng)SQL_TRACE,最好不要一直打開該開關(guān),代價(jià)比較大。
alter session set sql_trace=true;
然后我們執(zhí)行一條sql語句。
最后關(guān)閉該開關(guān)的狀態(tài)。
alter session set sql_trace=false;
我們可以從目錄%ORACLE_BASE%/diag/rdbms/orcl/orcl/trace(11g版本的路徑,如果是10g的應(yīng)該不一樣)中
找到自己定義的trace文件。
原始的trace文件的可讀性不高,我們一般使用oracle自帶的工具,tkprof來處理這個(gè)trace文件。我們可以查看tkprof的幫助。
tkprof orcl_ora_3820_mytest.trc out.txt
我們來看剛才生成的trace文件,頭部信息描述了tkprof 的版本以及報(bào)告中一些列的含義,對(duì)于任何一條sql語句,都應(yīng)該包含Parse—sql分析階段,Execute—sql執(zhí)行階段,F(xiàn)etch—數(shù)據(jù)提取階段,橫向的列如圖所示,包含消耗cpu時(shí)間0.00秒,操作總耗時(shí)0.04秒,物理讀取了0個(gè)數(shù)據(jù)塊,沒有發(fā)生current方式的讀取(一般在update會(huì)發(fā)生),一共提取記錄1條。
Misses in library cache during parse: 0表示這是一次軟分析(關(guān)于硬分析和軟分析下面會(huì)接著談到)
Optimizer mode: ALL_ROWS表示oracle的優(yōu)化器模式為ALL_ROWS。這也就是前面提到的另外的分析方式優(yōu)化器。
下面是sql執(zhí)行的具體計(jì)劃,可以看到執(zhí)行計(jì)劃選擇的是全表掃描。
經(jīng)過處理以后的trace文件的確比較容易看明白,它有助于我們分析sql的性能問題。
下面我通過一個(gè)trace實(shí)例來解釋一下,為什么OLTP系統(tǒng)中需要變量綁定機(jī)制。
當(dāng)用戶和數(shù)據(jù)庫建立連接,并發(fā)送一條sql語句以后,oracle會(huì)對(duì)該sql進(jìn)行hash函數(shù)運(yùn)算(hash算法提供了一種快速存取數(shù)據(jù)的方法,它用一種算法建立鍵值與真實(shí)值之間的對(duì)應(yīng)關(guān)系,每一個(gè)真實(shí)值只能有一個(gè)鍵值,但是一個(gè)鍵值可以對(duì)應(yīng)多個(gè)真實(shí)值,以方便存取),得到一個(gè)hash值,然后到共享池中尋找是否有匹配的hash值的sql存在,如果有,就直接使用該sql的執(zhí)行計(jì)劃去執(zhí)行sql。如果沒有,oracle就會(huì)認(rèn)為這是一條新的sql語句,然后按照語法分析,語義分析,生成執(zhí)行計(jì)劃,執(zhí)行sql這些步驟來執(zhí)行最終把結(jié)果返回給用戶。這些步驟也被成為硬分析,可以想象,如果減少硬分析,能夠大大降低數(shù)據(jù)庫花費(fèi)在sql解析上的資源開銷。
我們先執(zhí)行一條sql 1000次,比較綁定變量和不綁定變量的差異。得到結(jié)果以后,要計(jì)算實(shí)際的消耗,我們需要把OVERALL TOTALS FOR ALL NON-RECURSIVE STATEMENTS以及OVERALL TOTALS FOR ALL RECURSIVE STATEMENTS的時(shí)間累計(jì)起來,前者表示數(shù)據(jù)字典表的相關(guān)的信息,包含權(quán)限控制等,后者表示sql所衍生出的遞歸sql語句的信息。可以看到綁定變量的,整條語句執(zhí)行時(shí)間為0.22+0.02=0.24秒,CPU時(shí)間0.18+0.03=0.21秒,分析次數(shù)3次,執(zhí)行次數(shù)1003次。而不綁定變量的時(shí)候,整條語句執(zhí)行時(shí)間為0.28+1.29=1.57秒,CPU時(shí)間0.31+1.26=1.57秒,分析次數(shù)1002次,執(zhí)行次數(shù)1003次。可見綁定變量的確能夠帶來更低的開銷。(如何設(shè)計(jì)數(shù)據(jù)庫中使用綁定變量也是和系統(tǒng)息息相關(guān)的,很多數(shù)據(jù)庫問題都是在設(shè)計(jì)以后就已經(jīng)存在的)
應(yīng)用級(jí)調(diào)優(yōu)分析:
就通常所說的三層架構(gòu)來說,中間件這一層能夠起到一個(gè)緩沖池的作用,如果并發(fā)用戶數(shù)到3000這個(gè)數(shù)量級(jí)的時(shí)候,中間件能夠控制不是所有的用戶都能直接連接到數(shù)據(jù)庫,當(dāng)然這里的程序會(huì)快速響應(yīng)用戶請(qǐng)求,保證緩沖池的隊(duì)列等待不會(huì)很久。
對(duì)應(yīng)用這一級(jí)別的調(diào)優(yōu),主要集中在app程序,中間件的監(jiān)控,集群配置等方面。如果是發(fā)現(xiàn)應(yīng)用級(jí)別的問題,首先要分析是配置問題,還是程序本身的問題。如果并發(fā)用戶數(shù)很大,中間件的線程池最大值配置過小,會(huì)導(dǎo)致在請(qǐng)求隊(duì)列堆積,表現(xiàn)就是線程監(jiān)控視圖中,請(qǐng)求的隊(duì)列堆積比較多,一般可以調(diào)整線程池最大值來解決。我們來看看weblogic的監(jiān)控視圖。
考慮到如果為每一個(gè)請(qǐng)求都創(chuàng)建一個(gè)新線程來處理的話,那么我們難以在系統(tǒng)中實(shí)現(xiàn)足夠數(shù)量的線程。不受限制的創(chuàng)建線程可能耗盡系統(tǒng)資源,因此引入了線程池。線程池的思想是在進(jìn)程開始時(shí)創(chuàng)建一定數(shù)量的線程并將它們置入一個(gè)池(pool)中,線程在這個(gè)池中等待工作。當(dāng)服務(wù)器接收到一個(gè)請(qǐng)求時(shí),它就從池中喚醒一個(gè)線程(如果有可用的線程),由它來處理請(qǐng)求。一旦線程服務(wù)完畢,它就返回線程池等待后面的工作。
線程池利用已存在的線程服務(wù)請(qǐng)求要比等待創(chuàng)建一個(gè)線程要快,并且線程池限制了線程的數(shù)量。
如果懷疑是程序的問題,我們一般可以通過java自帶的工具來幫助分析,工具很多。這里我主要提到一個(gè)jdk1.6以后附帶的jvisualvm。
我們打開jdk1.6,找到并運(yùn)行jvisualvm.exe。
我們發(fā)現(xiàn)應(yīng)用程序分為本地,遠(yuǎn)程兩部分。本地包含本地運(yùn)行的java進(jìn)程,遠(yuǎn)程能夠通過配置連接到遠(yuǎn)程服務(wù)器上的java進(jìn)程。我們先啟動(dòng)一個(gè)tomcat。可以看到本地應(yīng)用程序已經(jīng)打開了一個(gè)帶有tomcat以及進(jìn)程標(biāo)識(shí)id的菜單。雙擊打開。這里我們一般關(guān)心2個(gè)視圖。監(jiān)視、線程。
其中監(jiān)視視圖比較關(guān)心垃圾回收活動(dòng)(顧名思義,回收那些在程序里面不再使用到的內(nèi)存空間),堆內(nèi)存變化。如果在壓力測(cè)試過程中,堆內(nèi)存變化是一個(gè)逐漸上漲的趨勢(shì),并且經(jīng)過多次手動(dòng)gc回收,還是保持這個(gè)趨勢(shì),說明內(nèi)存泄漏的可能性很大。如果猜測(cè)有內(nèi)存泄漏,可以通過分析java的heap dump。JVM (java虛擬機(jī))記錄下問題發(fā)生時(shí)系統(tǒng)的運(yùn)行狀態(tài)并將其存儲(chǔ)在轉(zhuǎn)儲(chǔ)(dump)文件中。Heap dump就是這樣一種文件形式。
線程視圖比較關(guān)心線程的當(dāng)前執(zhí)行狀態(tài),這里可以生成另一種轉(zhuǎn)儲(chǔ)文件 Java dump。Java dump,也叫做 Thread dump,是 JVM 故障診斷中最重要的轉(zhuǎn)儲(chǔ)文件之一。JVM 的許多問題都可以使用這個(gè)文件進(jìn)行診斷,其中比較典型的包括線程阻塞,CPU 使用率過高,JVM Crash,堆內(nèi)存不足,和類裝載等問題。其中線程阻塞更加常見。
1、安裝并打開toad可視化工具。
2、輸入服務(wù)器名或服務(wù)器Ip地址、數(shù)據(jù)庫用戶名及密碼,成功連接到數(shù)據(jù)庫。
3、進(jìn)入軟件界面。
4、如果你看到的界面不同,首先點(diǎn)擊“Editor”——“SQL”按鈕,即可打開 sql語句編輯窗口。
5、然后在Current Schema編輯窗口中,輸入sql語句,測(cè)試語句最好不要使用改變數(shù)據(jù)庫結(jié)構(gòu)和數(shù)據(jù)的語句。
6、然后按F5或點(diǎn)擊如圖按鈕運(yùn)行SQl語句。底部“grid1”中可以看到運(yùn)行結(jié)果。
使用sql語句,查詢oracle的表注釋等信息方法如下:
一、Oracle 下讀取表/字段的備注信息,Oracle 通過COMMENT ON TABLE? /? COMMENT ON COLUMN 追加表/字段的備注。
COMMENT ON TABLE ,MR_DEPT,IS 。
COMMENT ON COLUMN ,MR_DEPTDEPT_ID,IS。
COMMENT ON COLUMN ,MR_DEPT"PARENT_ID,IS。
COMMENT ON COLUMN ,MR_DEPT"DEPT_NAME,IS 。
COMMENT ON COLUMN ,MR_DEPT"STATUS,IS 。
二、查詢表的備注信息
SELECT。
TABLE_NAME。
TABLE_TYPE。
COMMENTS。
FROM。
USER_TAB_COMMENTS。
WHERE-TABLE_NAME -MR_DEPT。
三、查詢字段的備注信息
TABLE_NAME。
COLUMN_NAME。
COMMENTS
FROM。
USER_COL_COMMENTS。
WHERE-TABLE_NAME - 'MR_DEPT。
方法如下:
1:運(yùn)行cmd進(jìn)入命令行界面
2:進(jìn)入到存放批量sql的文件夾下面
3:輸入命令
sqlplus
數(shù)據(jù)庫名/密碼@數(shù)據(jù)庫
按回車鍵
4:輸入spool
指定路徑:\a.log
按回車鍵
(此步驟的主要作用就是追蹤批量執(zhí)行sql的日志,路徑隨便寫,只要能找到就行,a.log可以隨便起名,但是必須要.log后綴)
5:@start.sql
按回車鍵(在批量sql文件夾下寫一個(gè)文件,名字叫start.sql,其中在這個(gè)文件里面寫批量sql的文件名)
具體格式如下:@@sql的文件名.sql;
@@sql的文件名2.sql;
6:spool
off
(此時(shí)a.log中所有日志已經(jīng)寫入完畢)
7:exit
退出sqlplus
當(dāng)然只有一個(gè)sql文件,但是里面有多個(gè)insert語句,數(shù)據(jù)量非常大,此時(shí)也可以在命令狀態(tài)下執(zhí)行,前4步是一樣的,第五步就是@文件名.sql;
名稱欄目:oracle怎么用sql,oracle怎么用命令創(chuàng)建數(shù)據(jù)庫
網(wǎng)頁地址:http://vcdvsql.cn/article34/dsdgpse.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供標(biāo)簽優(yōu)化、企業(yè)網(wǎng)站制作、網(wǎng)站策劃、網(wǎng)站營銷、響應(yīng)式網(wǎng)站、面包屑導(dǎo)航
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)