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列很唯一的。
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使用者執行