关于会话、进程、请求的几个常用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>



转载于:https://www.cnblogs.com/wanghang/p/6299247.html

### 如何在 SQL Server 中查看所有进程SQL Server 中,可以使用多种方法来查看当前运行的所有进程。以下是几种常见的方法: #### 方法一:使用 `sp_who` 和 `sp_who2` 存储过程 SQL Server 提供了内置的存储过程 `sp_who` 和 `sp_who2` 来显示当前连接到服务器的会话及其相关信息。 - **`sp_who`**: 显示基本的信息,包括 SPID(Session ID)、状态和登录名。 ```sql EXEC sp_who; ``` - **`sp_who2`**: 提供更详细的输出,包括 CPU 时间、磁盘 I/O 和最后一批执行的时间等信息[^1]。 ```sql EXEC sp_who2; ``` #### 方法二:查询动态管理视图 (DMV) 可以通过查询系统动态管理视图 (Dynamic Management Views, DMVs) 获取更多关于活动进程的细节。常用的 DMV 是 `sys.dm_exec_requests` 和 `sys.dm_exec_sessions`。 - 查询当前正在执行的请求: ```sql SELECT session_id AS SPID, status, command, start_time, cpu_time, total_elapsed_time, database_id, blocking_session_id AS BlockingSPID FROM sys.dm_exec_requests; ``` 此查询返回每个请求的状态、命令类型、启动时间、CPU 使用情况以及其他重要属性[^2]。 - 结合会话信息获取完整的上下文: ```sql SELECT s.session_id AS SPID, s.login_name, r.status, r.command, r.cpu_time, r.total_elapsed_time, t.text AS LastBatchText FROM sys.dm_exec_sessions s LEFT JOIN sys.dm_exec_requests r ON s.session_id = r.session_id CROSS APPLY sys.dm_exec_sql_text(r.sql_handle) t; ``` 这段脚本不仅展示了各个会话的基本详情,还附加了解析后的最近批处理文本[^3]。 #### 方法三:利用扩展事件或性能监视器 对于高级监控需求,还可以启用扩展事件或者配置 Windows 性能计数器来跟踪长时间运行的任务或其他异常行为。不过这些方式通常适用于持续性的诊断场景而非即时观察。 --- ### 示例代码总结 为了方便操作,这里再次列举几个核心语句作为参考: ```sql -- 基础版:列出所有活跃会话 EXEC sp_who; -- 高级版:提供更多字段支持分析阻塞等问题 EXEC sp_who2; -- 动态管理视图版本:适合深入挖掘具体指标 SELECT * FROM sys.dm_exec_requests WHERE session_id > 50; -- 过滤掉内部系统线程 ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值