最新活动:电脑PC端+手机端+微网站+自适应网页多模板选择-建站388元起价!!!
当前位置:主页 > 网站建设 > 探讨:Oracle数据库查看一个进程是如何执行相关的

探讨:Oracle数据库查看一个进程是如何执行相关的

时间:2023-05-23 16:05:23 阅读: 文章分类: 网站建设 作者: 网站技术员

导读:1建站知识本篇文章是对Oracle数据库查看一个进程是如何执行相关的实际SQL语句进行了详细的分析介绍,需要的朋友参考下百度seo网站优化高端网站建设。

百度seo网站优化高端网站建设Oracle数据库查看一个进程是如何执行相关的实际SQL语句

复制代码 代码如下:

SELECT b.sql_text, sid, serial#, osuser, machine FROM v$session a, v$sqlarea b WHERE a.sql_address = b.address;

查询前台发出的SQL语句.

复制代码 代码如下:

select user_name,sql_text from v$open_cursor where sid in (select sid from (select sid,serial#,username,program from v$session where status='ACTIVE'));

根据SPID查询session

复制代码 代码如下:

SELECT * FROM v$session WHERE paddr IN (SELECT addr FROM v$process WHERE spid=&spid);

根据SID查询process

复制代码 代码如下:

SELECT * FROM v$process WHERE addr IN (SELECT paddr FROM v$session WHERE sid=&sid);

DBA如何查询其他用户所进行的操作

复制代码 代码如下:

SELECT sql_text FROM v$sql t1, v$session t2 WHERE t1.address = t2.sql_address AND t2.sid = &sid;

根据process查询sql语句

复制代码 代码如下:

SELECT sql_text FROM v$sqltext a WHERE (a.hash_value, a.address) IN ( SELECT DECODE (sql_hash_value,0, prev_hash_value,sql_hash_value ), DECODE (sql_hash_value, 0, prev_sql_addr, sql_address) FROM v$session b WHERE b.paddr = (SELECT addr FROM v$process c WHERE c.spid = '$processID'))ORDER BY piece ASC;

其他执行下列命令语句

复制代码 代码如下:

sqlplus / as sysdba <<EOFcreate tablespace test datafile '/data/test01.dbf' size 10240M;quit;EOF

通过ps -ef|grep sqlplus命令得到上面所执行的命令的进程id为:12345(1)关于v$process执行下面的SQL是查不到相关的信息:select * from v$process where spid='12345';因为这个spid字段对应的并不是我们用ps命网站优化seo培训令网站建设多少钱从系统中查询到的进程id,而是这个进程执行的当前SQL的进程id,也就是上面命令中的“create tablespace test datafile '/data/test01.dbf' size 10240M;”所对应的进程id,如果想通过用ps命令从系统中查询到的进程id查看对应的信息,那么必须使用下面语句:select spid,sid,process,sql_address from v$session where process='12345'上面sql中的process就是通过ps查看的进程id,而spid就是里面的sql语句所对应的进程id。还可以通过上面的sql_address 查看正在执行的SQL语句内容:select sql_text from v$sqlarea s,v$session ses where s.address=ses.sql_address and ses.process='12345';(2)关于v$session在查询 v$session 视图的时候,我们根据command字段内部表示解码每一个字段,当我们需要快速找出他们的 Oracle 系统的内部情况时非常有用。

复制代码 代码如下:

selectsubstr(s.username,1,18) username,substr(s.program,1,15) program,p.spid,s.process,decode(s.command,0,'No Command',1,'Create Table',2,'Insert',3,'Select',6,'Update',7,'Delete',9,'Create Index',15,'Alter Table',21,'Create View',23,'Validate Index',35,'Alter Database',39,'Create Tablespace',41,'Drop Tablespace',40,'Alter Tablespace',53,'Drop User',62,'Analyze Table',63,'Analyze Index',s.command||': Other') commandfromv$session s,v$process p,v$transaction t,v$rollstat r,v$rollname nwhere s.paddr = p.addrand s.taddr = t.addr (+)and t.xidusn = r.usn (+)and r.usn = n.usn (+)order by username

关键词标签: SQL 语句 进程

声明: 本文由我的SEOUC技术文章主页发布于:2023-05-23 ,文章探讨:Oracle数据库查看一个进程是如何执行相关的主要讲述语句,进程,SQL网站建设源码以及服务器配置搭建相关技术文章。转载请保留链接: https://www.seouc.com/article/web_5931.html

我的IDC 网站建设技术SEOUC.COM
专注网站建设,SEO优化,小程序设计制作搭建开发定制网站等,数千家网站定制开发案例,网站推广技术服务。
  • 5000+合作客服
  • 8年从业经验
  • 150+覆盖行业
  • 最新热门源码技术文章