1. 程式人生 > >PLSQL執行sql的幾種方法

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

\

2)匯入dmp檔案。匯入dmp檔案前先刪除對應的user(下面以test_user為例)

drop user test_user cascade;
$ impdp 

system/[email protected] 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 systemkillsession'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(看當前有多少個連線使用者等

相關推薦

Linux 技巧:讓進程在後臺可靠執行方法

stl 選項 con 中斷 program ng- dem 不同 正在 我們常常會碰到這種問題。用 telnet/ssh 登錄了遠程的 Linux server,執行了一些耗時較長的任務, 結果卻因為網絡的不穩定導致任務中途失敗。怎樣讓命令提交後不受本地關閉終端

linux shell 多個命令一起執行方法

在命令列可以一次執行多個命令,有以下幾種: 1.每個命令之間用;隔開 說明:各命令的執行結果,不會影響其它命令的執行。換句話說,各個命令都會執行, 但不保證每個命令都執行成功。 cd /home/PyTest/src; python suning.py

讓Python指令碼暫停執行方法(轉載)

轉自:讓Python指令碼暫停執行的幾種方法 1.time.sleep(secs) 參考文件原文: Suspend execution for the given number of seconds. The argument may be a

IOS開發之延時執行方法

1.最直接的方法performSelector:withObject:afterDelay: 這種方法的缺點:每次要為延時寫一個方法 2.使用類別,用BOLCK執行 [程式碼]c#/cpp/oc程式碼: 01 @implementation NSObje

讓程序在後臺可靠執行方法

簡介: 想讓程序在斷開連線後依然保持執行?如果該程序已經開始運行了該如何補救? 如果有大量這類需求如何簡化操作? 我們經常會碰到這樣的問題,用 telnet/ssh 登入了遠端的 Linux 伺服器,運行了一些耗時較長的任務, 結果卻由於網路的不穩定導致任務中途失

asp.net 執行js 方法

方法二: <asp:Literal ID="ltScript" runat="server"></asp:Literal> 然後使用Literal類,在後臺程式碼使用時 private void Button1_Click(object sender

iOS延時執行方法

1. 最直接的方法performSelector:withObject:afterDelay: 這種方法的缺點:每次要為延時寫一個方法 2. @implementation NSObject (PerformBlockAfterDelay) - (void)p

Linux 技巧:讓程序在後臺可靠執行方法

我們經常會碰到這樣的問題,用 telnet/ssh 登入了遠端的 Linux 伺服器,運行了一些耗時較長的任務, 結果卻由於網路的不穩定導致任務中途失敗。如何讓命令提交後不受本地關閉終端視窗/網路斷開連線的干擾呢?下面舉了一些例子, 您可以針對不同的場景選擇不同的方式來處理這

android 終止執行方法

其實android 不提倡我們終止執行緒的,以前的一些函式,stop等等都不推薦使用了,但是當我們確實要終止執行緒的時候,可看考下面的問題 有時當一個元件或者activity被destory()的時候要求其啟動的執行緒也一起終止掉,現在就來總結了一下有這有幾種方法:

vs中獲取當前exe檔案執行路徑方法

1、 TCHAR szFilePath[MAX_PATH + 1];  GetModuleFileName(NULL, szFilePath, MAX_PATH);  (_tcsrchr(szFilePath, _T('//')))[1] = 0;//刪除檔名,只獲得路

Linux 技巧:讓程序在後臺可靠執行方法&CentOS 7通過Firewall開放防火牆埠

一.讓程序在後臺可靠執行的幾種方法 方法1 #nohup  【命令】 & 例: [[email protected] ~]# nohup ping www.ibm.com & 方法2 # (【命令】 &) 例:  # (ping www.i

PLSQL執行sql方法

plsql很方便我們執行sql。下面就簡單介紹我常用的幾種(當然每次svn的分支也可以ant指令碼自動執行某個檔案下的所以sql檔案) 首先開啟plsq的命令視窗 1)執行sql檔案(可以把需要執行的sql放一個檔案中) 輸入 @''   在單引號中輸入sql檔案的路徑既可

asp執行sql語句、儲存過程的方法

使用connection物件 會返回一個關閉的recordset記錄集,此記錄集不要再次宣告關閉 建議在update、insert、delete時使用 strCon="provider=sqloledb;data source=servername;initial catalog

SQL Server遍歷表的方法

都是 遍歷 lec delet -s rop itl 想要 temp  在數據庫開發過程中,我們經常會碰到要遍歷數據表的情形,一提到遍歷表,我們第一印象可能就想到使用遊標,使用遊標雖然直觀易懂,但是它不符合面向集合操作的原則,而且性能也比面向集合低。當然,從面向集合操作的角

SQL重復記錄查詢的方法

people tro ati from itl ebo del pan select http://www.jb51.net/article/34820.htm \ 1、查找表中多余的重復記錄,重復記錄是根據單個字段(peopleId)來判斷 復制代碼 代碼如下: se

sql脫庫的方法

發現 navi 無法 postgresq 進行 posit 過程 highlight 構造 當發現sql註入之後,脫庫的方法,有以下幾種: (1)當目標主機支持外部連接時,使用Navicat 進行連接!當時目標主機不同,使用的Navicat種類不一樣: mysql :

mysql 優化sql語句的方法

化sql語句的幾種方法 1、通過show status命令瞭解SQL的執行效率 show [session|global]status like 'com_%'; 2、定位執行效率較低的SQL語句 1)慢查詢   開啟方法 linux: 配置檔案(/etc/m

檢視某個程序執行時間的方法

1.首先查出某個程序的pid,然後使用ps命令 [[email protected] ~]# jps 2640 Jps 2339 DataNode 2239 NameNode [[email protected] ~]# ps -p 2239 -o etime ELAPSE

歸納一下:C#執行緒同步的方法

 我們在程式設計的時候,有時會使用多執行緒來解決問題,比如你的程式需要在後臺處理一大堆資料,但還要使使用者介面處於可操作狀態;或者你的程式需要訪問一些外部資源如資料庫或網路檔案等。這些情況你都可以建立一個子執行緒去處理,然而,多執行緒不可避免地會帶來一個問題,就是執行緒同步的問題。如果這個問題處理不好,我們就

sql語句優化的方法

在sql查詢中為了提高查詢效率,我們常常會採取一些措施對查詢語句進行sql優化,下面總結的一些方法,有需要的可以參考參考。 1.對查詢進行優化,應儘量避免全表掃描,首先應考慮在 where 及 order by 涉及的列上建立索引。