天天看點

pl/sql執行sql 幾種方式

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='銷售訂單' ;)

pl/sql執行sql 幾種方式

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'就行了,參考下面的截圖:

pl/sql執行sql 幾種方式

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

 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使用者執行

繼續閱讀