Как вы можете показать SQL, который в настоящее время выполняется на оракуле БД?
Дополнительная информация, которая будет полезна, будет включать пользователя, идентификатор сеанса и т. Д.
Большая часть информации доступна в v $ session ... и текст SQL можно получить из v $ sql или v $ sqltext_with_newlines ...
Вот запрос, который я часто использую, который форматирует In-flight SQL, самый длинный из которых работает сверху.
-- In Flight SQL
SELECT nvl(ses.username,'ORACLE PROC')||' ('||ses.sid||')' USERNAME,
SID,
MACHINE,
REPLACE(SQL.SQL_TEXT,CHR(10),'') STMT,
ltrim(to_char(floor(SES.LAST_CALL_ET/3600), '09')) || ':'
|| ltrim(to_char(floor(mod(SES.LAST_CALL_ET, 3600)/60), '09')) || ':'
|| ltrim(to_char(mod(SES.LAST_CALL_ET, 60), '09')) RUNT
FROM V$SESSION SES,
V$SQLtext_with_newlines SQL
where SES.STATUS = 'ACTIVE'
and SES.USERNAME is not null
and SES.SQL_ADDRESS = SQL.ADDRESS
and SES.SQL_HASH_VALUE = SQL.HASH_VALUE
and Ses.AUDSID <> userenv('SESSIONID')
order by runt desc, 1,sql.piece;
Хороший ответ найден здесь .
Выполните следующий sql:
Если вывод не читается, измените LINESIZE (возьмите отсюда ):
Если sql выше не работает, вам может потребоваться войти в систему как sysdba:
источник