关于会话、进程、请求的几个常用SQL

1.检查自己的SID

SELECT sid FROM v$session WHERE sid = (SELECT sid FROM v$mystat WHERE rownum = 1);

2. 几个ID之间的关系

SELECT s.sid session_id, p.spid os_process_id, p.pid oracle_process_id
  FROM v$process p, v$session s
 WHERE p.addr = s.paddr;

3.杀死Session和进程

SELECT s.sid session_id,
       p.spid os_process_id,
       p.pid oracle_process_id,
       'alter system kill session ''' || to_char(s.sid) || ',' || to_char(s.serial#) || ''' immediate;' kill_db_session,
       'kill -9 ' || p.spid kill_os_session
  FROM v$process p, v$session s
 WHERE p.addr = s.paddr
   AND s.sid = &sid;
   

4.正在执行的SQL

   SELECT sql_text
  FROM v$sqltext_with_newlines sqlt, v$session s
 WHERE sqlt.address = s.sql_address
   AND sqlt.hash_value = s.sql_hash_value
   AND s.sid = &session_id
 ORDER BY piece

5.引用对象的Session,锁表session

 SELECT acc.*,
       'alter system kill session ''' || to_char(ses.sid) || ',' || to_char(ses.serial#) ||
       ''' immediate'
  FROM v$access acc, v$session ses
 WHERE acc.OBJECT LIKE upper('TABLE_NAME%')
   AND acc.sid = ses.sid;

6.请求的Session和SQL

<span style="font-size:18px;">SELECT to_char(s.sid) || ',' || to_char(s.serial#), sql_text
  FROM applsys.fnd_concurrent_requests r,
       v$process                       p,
       v$session                       s,
       v$sqltext_with_newlines         sqlt
 WHERE r.oracle_process_id = p.spid
   AND p.addr = s.paddr(+)
   AND s.sql_address = sqlt.address(+)
   AND s.sql_hash_value = sqlt.hash_value(+)
   AND r.request_id = &request_id
 ORDER BY piece;
</span>

关于会话、进程、请求的几个常用SQL

时间: 2024-10-21 23:33:44

关于会话、进程、请求的几个常用SQL的相关文章

C# 会话,进程,线程,线程安全

会话->进程->线程 b/s网站中,每个用户的访问为一次会话,会话中包含CPU为用户在内存中开辟空间存储的会话信息, 如Session,进程,会话拥有一个进程,同一进程下可以拥有多个线程. 会话,进程,线程数量: 1.用户在同一浏览器(会话)请求页面时如果只打开一个页面, 会话(1)->进程(1)->线程(1). 2.用户在同一浏览器(会话)请求页面时,打开多个窗口 会话(1)->进程(1)->线程(N). 非线程安全: 多数情况下指的是静态变量\全局变量等,如果是静态

查询当前会话进程号

select P.SPID, s.status, S.sid,S.serial#,S.username,S.machine,S.program,S.osuser,to_char(S.logon_time,'yyyy/mm/dd-hh24:mi:ss'),s.audsid from v$process P,  v$session S WHERE P.addr = S.paddr  AND s.audsid = userenv('sessionid') --audsid: Auditing sess

spring:使用会话和请求作用域

在Web应用中,如果能够实例化在会话和请求范围内共享的bean,那将是非常有价值的事情.例如,在典型的电子商务应用中,可能会有一个bean代表用户的购物车.如果购物车是单例的话,那么将会导致所有的用户都会向同一个购物车中添加商品.另一方面,如果购物车是原型作用域的,那么在应用中某一个地方往购物车中添加商品,在应用的另外一个地方可能就不可用了,因为在这里注入的是另外一个原型作用域的购物车.就购物车bean来说,会话作用域是最为合适的,因为它与给定的用户关联性最大.要指定会话作用域,我们可以使用@S

DBA_Oracle DBA常用SQL汇总(概念)

2014-06-20 BaoXinjian DBA常用的SQL汇总 1.监控索引是否使用 alter index &index_name monitoring usage; alter index &index_name nomonitoring usage; select * from v$object_usage where index_name = &index_name; 2.求数据文件的I/O分布 select df.name,phyrds,phywrts,phyblkr

Oracle维护常用SQL语句

数据库人员手边系列:Oracle维护常用SQL语句 1.查看表空间的名称及大小 select t.tablespace_name, round(sum(bytes/(1024*1024)),0) ts_size from dba_tablespaces t, dba_data_files d where t.tablespace_name = d.tablespace_name group by t.tablespace_name; 2.查看表空间物理文件的名称及大小 select tables

SQL SERVER错误:已超过了锁请求超时时段。 (Microsoft SQL Server,错误: 1222)

在SSMS(Microsoft SQL Server Management Studio)里面,查看数据库对应的表的时候,会遇到"Lock Request time out period exceeded.(Microsoft SQL Server, 错误1222)",对应的中文错误提示为"已超过了锁请求超时时段. (Microsoft SQL Server,错误: 1222)",如下截图所示,不管是用一般权限的账号还是具有sysadmin角色的登录名都是如此. 这

Oracle数据库常用Sql语句大全

一,数据控制语句 (DML) 部分 1.INSERT  (往数据表里插入记录的语句) INSERT INTO 表名(字段名1, 字段名2, --) VALUES ( 值1, 值2, --); INSERT INTO 表名(字段名1, 字段名2, --)  SELECT (字段名1, 字段名2, --) FROM 另外的表名; 字符串类型的字段值必须用单引号括起来, 例如: 'GOOD DAY' 如果字段值里包含单引号' 需要进行字符串转换, 我们把它替换成两个单引号''. 字符串类型的字段值超过

oracle常用SQL语句(汇总版)

Oracle数据库常用sql语句 ORACLE 常用的SQL语法和数据对象 一.数据控制语句 (DML) 部分 1.INSERT (往数据表里插入记录的语句) INSERT INTO 表名(字段名1, 字段名2, ……) VALUES ( 值1, 值2, ……); INSERT INTO 表名(字段名1, 字段名2, ……) SELECT (字段名1, 字段名2, ……) FROM 另外的表名; 字符串类型的字段值必须用单引号括起来, 例如: ’GOOD DAY’ 如果字段值里包含单引号’ 需要

处理数据库的常用SQL(SQL SERVER)

常用SQL-- 查看表记录数SELECT a.id, b.[name], a.rowcnt FROM sysindexes a, sys.tables b WHERE a.id = b.[object_id] AND a.indid <=1 ORDER BY b.[name] -- 查看文件组SELECT name, data_space_id 文件组id, size/128 [文件大小(兆)],FILEPROPERTY(name, 'SpaceUsed')/128 [已用空间(兆)],size