PLSQL執行sql的幾種方法

 
PLSQL執行sql的幾種方法
2012-02-02 21:13:22     我來說兩句 
收藏    我要投稿    [字體: ]

plsql很方便我們執行sql。下面就簡單介紹我常用的幾種(當然每次svn的分支也可以ant腳本自動執行某個文件下的所以sql文件)

首先打開plsq的命令窗口

1)執行sql文件(可以把需要執行的sql放一個文件中)

輸入 @''  

在單引號中輸入sql文件的路徑既可,比如D:\db下的jbpm.oracle.sql文件,見下圖(sql文件內容是select * from system_menu r where r.menu_name='銷售訂單' ;)

\

 

 

2)導入dmp文件。導入dmp文件前先刪除對應的user(下面以test_user爲例)

drop user test_user cascade;
$ impdp system/test123@SYSTEM directory=data_pump_dir schemas=test_user dumpfile=date.DMP REMAP_SCHEMA=test_user:test_userTABLE_EXISTS_ACTION=replace logfile=imp.log;
alter user test_user identified by 123456;

 

 

3)當需要重新從正式版數據庫到數據到測試版時,我們需要重啓測試版服務器或者kill掉應用程序服務器(比如tomcat)的session連接

v$session 這張表可以查找到連接 oracle 數據庫的應用程序基本信息。因此可以通過該表來kill掉相應程序的session

如果你想kill到連接到用戶 test_user ,可以執行下面的sql: select * from v$session r where r.USERNAME=‘test_user’ ;

然後kill對應的session'就行了,參考下面的截圖:

\

 

比如你要kill 第一條;就執行下面的sql :  alter system kill session '21,77' ;   //因爲sid, serial#.這2列很唯一的。

 

 

下面補充一些連接oracle的應用程序信息和oracle 操作 session 情況。       

 1.查找到連接 oracle 數據庫的應用程序基本信息。

 

select sid, serial#,  
username, --連接用戶名  
program, --應用程序名
machine, --機器名
osuser, --操作系統用戶
logon_time --登錄時間
from v$session;

   2.如何查看session級的等待事件?

當我們對數據庫的性能進行調整時,一個最重要的參考指標就是系統等待事 件。$system_event,v$session_event,v$session_wait這三個視圖裏記錄的就是系統級和session級的等待 事件,通過查詢這些視圖你可以發現數據庫的一些操作到底在等待什麼?是磁盤I/O,緩衝區忙,還是插鎖等等。

通過如下sql你可以查詢你的每個應用程序到底在等待什麼,從而針對這些信息對數據庫的性能進行調整。
Select s.username,s.program,s.status,se.event,se.total_waits,se.total_timeouts,se.time_waited,se.average_wait
from v$session s, v$session_event se
Where s.sid=se.sid And se.event not like 'SQl*Net%' And s.status ='ACTIVE'And s.username is not null

 

3.oracle中查詢被鎖的表並釋放session
SELECT A.OWNER,A.OBJECT_NAME,B.XIDUSN,B.XIDSLOT,B.XIDSQN,B.SESSION_ID,B.ORACLE_USERNAME, B.OS_USER_NAME,B.PROCESS, B.LOCKED_MODE, C.MACHINE,C.STATUS,C.SERVER,C.SID,C.SERIAL#,C.PROGRAM
FROM ALL_OBJECTS A,V$LOCKED_OBJECT B,SYS.GV_$SESSION C
WHERE ( A.OBJECT_ID = B.OBJECT_ID ) AND (B.PROCESS = C.PROCESS ) ORDER BY 1,2

釋放session Sql:
alter system killsession'sid,serial#'
alter systemkillsession'379,21132'
alter systemkillsession'374,6938'

4.查看佔用系統io較大的session
SELECT se.sid,se.serial#,pr.SPID,se.username,se.status,se.terminal,se.program,se.MODULE,se.sql_address,st.event,st.p1text,si.physical_reads,si.block_changes
FROM v$session se, v$session_wait st,v$sess_io si,v$process pr
WHERE st.sid=se.sid  AND st.sid=si.sid AND se.PADDR=pr.ADDR AND se.sid>6 AND st.wait_time=0 AND st.event NOT LIKE '%SQL%' ORDER BY physical_reads DESC

5.找出耗cpu較多的session
select a.sid,spid,status,substr(a.program,1,40) prog,a.terminal,osuser,value/60/100 value
from v$session a,v$process b,v$sesstat c
where c.statistic#=12 and c.sid=a.sid and a.paddr=b.addr order by value desc
     6.另外oracle是否運行可以用sql語句查出:

select   status   from  v$instance; 
其中,status可能返回三種值:open(數據庫打開),mount(數據庫已經加載,但還沒有打開),started(數據庫進程已經啓動,但是還沒有加載),這個數據字典可以在數據庫沒有打開的情況下查詢,但是需要用sys用戶執行。
反應時間,請求數需要具體說明到底是那個參數。你可以參考字典;v$status,v$session(看當前有多少個連接用戶等).

 

 
點擊複製鏈接 與QQ/MSN好友分享!
分享到:      
您對本文章有什麼意見或着疑問嗎?請到論壇討論您的關注和建議是我們前行的參考和動
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章