PLSQL执行sql的几种方法

蔷薇部落 2012-09-19

plsql很方便我们执行sql。下面就简单介绍我常用的几种(当然每次svn的分支也可以ant脚本自动执行某个文件下的所以sql文件)

首先打开plsq的命令窗口

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

输入@''

在单引号中输入sql文件的路径既可,比如D:\db下的jbpm.oracle.sql文件,见下图(sql文件内容是select*fromsystem_menurwherer.menu_name='销售订单';)

2)导入dmp文件。导入dmp文件前先删除对应的user(下面以test_user为例)

dropusertest_usercascade;

$impdpsystem/test123@SYSTEMdirectory=data_pump_dirschemas=test_userdumpfile=date.DMPREMAP_SCHEMA=test_user:test_userTABLE_EXISTS_ACTION=replacelogfile=imp.log;

alterusertest_useridentifiedby123456;

3)当需要重新从正式版数据库到数据到测试版时,我们需要重启测试版服务器或者kill掉应用程序服务器(比如tomcat)的session连接

v$session这张表可以查找到连接oracle数据库的应用程序基本信息。因此可以通过该表来kill掉相应程序的session

如果你想kill到连接到用户test_user,可以执行下面的sql:select*fromv$sessionrwherer.USERNAME=‘test_user’;

然后kill对应的session'就行了,参考下面的截图:

比如你要kill第一条;就执行下面的sql:altersystemkillsession'21,77';//因为sid,serial#.这2列很唯一的。

下面补充一些连接oracle的应用程序信息和oracle操作session情况。

1.查找到连接oracle数据库的应用程序基本信息。

selectsid,serial#,

username,--连接用户名

program,--应用程序名

machine,--机器名

osuser,--操作系统用户

logon_time--登录时间

fromv$session;

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

当我们对数据库的性能进行调整时,一个最重要的参考指标就是系统等待事件。$system_event,v$session_event,v$session_wait这三个视图里记录的就是系统级和session级的等待事件,通过查询这些视图你可以发现数据库的一些操作到底在等待什么?是磁盘I/O,缓冲区忙,还是插锁等等。

通过如下sql你可以查询你的每个应用程序到底在等待什么,从而针对这些信息对数据库的性能进行调整。

Selects.username,s.program,s.status,se.event,se.total_waits,se.total_timeouts,se.time_waited,se.average_wait

fromv$sessions,v$session_eventse

Wheres.sid=se.sidAndse.eventnotlike'SQl*Net%'Ands.status='ACTIVE'Ands.usernameisnotnull

3.oracle中查询被锁的表并释放session

SELECTA.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

FROMALL_OBJECTSA,V$LOCKED_OBJECTB,SYS.GV_$SESSIONC

WHERE(A.OBJECT_ID=B.OBJECT_ID)AND(B.PROCESS=C.PROCESS)ORDERBY1,2

释放sessionSql:

altersystemkillsession'sid,serial#'

altersystemkillsession'379,21132'

altersystemkillsession'374,6938'

4.查看占用系统io较大的session

SELECTse.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

FROMv$sessionse, v$session_waitst,v$sess_iosi,v$processpr

WHEREst.sid=se.sid ANDst.sid=si.sidANDse.PADDR=pr.ADDRANDse.sid>6 ANDst.wait_time=0ANDst.eventNOTLIKE'%SQL%'ORDERBYphysical_readsDESC

5.找出耗cpu较多的session

selecta.sid,spid,status,substr(a.program,1,40)prog,a.terminal,osuser,value/60/100value

fromv$sessiona,v$processb,v$sesstatc

wherec.statistic#=12andc.sid=a.sidanda.paddr=b.addrorderbyvaluedesc

6.另外oracle是否运行可以用sql语句查出:

selectstatusfromv$instance;

其中,status可能返回三种值:open(数据库打开),mount(数据库已经加载,但还没有打开),started(数据库进程已经启动,但是还没有加载),这个数据字典可以在数据库没有打开的情况下查询,但是需要用sys用户执行。

反应时间,请求数需要具体说明到底是那个参数。你可以参考字典;v$status,v$session(看当前有多少个连

相关推荐

LetonLIU / 0评论 2020-05-29