2011-11-13 18 views
7

Así que tenemos este SYS_CONTEXT function en Oracle, que toma dos parámetros, primero un espacio de nombres, y segundo un nombre de parámetro. Hay un espacio de nombre predefinido llamado USERENV, y viene con varios parámetros, el número exacto y los nombres de los cuales dependen de la versión de Oracle que se utiliza.Lea todos los parámetros de SYS_CONTEXT/USERENV

El uso de Firefox y Firequery se puede obtener una lista de todos los nombres de los parámetros en la página doc Oracle vinculadas al anterior, así:

$("tr > td[id] > p > code").map(function() { return $(this).text() }) 

Y entonces se podría construir un procedimiento que lee y da salida a todo el contexto - al menos para la versión que ha elegido los parámetros.

Pero dejando de lado esta manera estática de leer el SYS_CONTEXT/USERENV, ¿hay una manera dinámica de hacerlo? ¿Algún lugar en el diccionario de datos que enumera los nombres de parámetros válidos del USERENV?

En cuanto a por qué me gustaría leer el USERENV, es solo para propósitos de estudio y curiosidad.

Respuesta

5

No hay forma de determinar los valores admitidos para el espacio de nombres userenv. Una forma sería crear una tabla con los nombres de parámetros admitidos.

+1

Gracias, bastante fácil de crear la tabla, 'crear USERENV mesa (varchar2 parámetro (30))', y luego (en SQL * Plus) 'formato de valor de la columna a50' y' seleccionar el parámetro, SYS_CONTEXT (' userenv ', parámetro) como el valor de userenv orden por parámetro'. – Lumi

12

Supongo que podría ser útil para usted. La siguiente consulta vacía el contexto de Oracle USERENV como una tabla.

select res.* 
    from (
     select * 
     from (
     select 
      sys_context ('userenv','ACTION') ACTION, 
      sys_context ('userenv','AUDITED_CURSORID') AUDITED_CURSORID, 
      sys_context ('userenv','AUTHENTICATED_IDENTITY') AUTHENTICATED_IDENTITY, 
      sys_context ('userenv','AUTHENTICATION_DATA') AUTHENTICATION_DATA, 
      sys_context ('userenv','AUTHENTICATION_METHOD') AUTHENTICATION_METHOD, 
      sys_context ('userenv','BG_JOB_ID') BG_JOB_ID, 
      sys_context ('userenv','CLIENT_IDENTIFIER') CLIENT_IDENTIFIER, 
      sys_context ('userenv','CLIENT_INFO') CLIENT_INFO, 
      sys_context ('userenv','CURRENT_BIND') CURRENT_BIND, 
      sys_context ('userenv','CURRENT_EDITION_ID') CURRENT_EDITION_ID, 
      sys_context ('userenv','CURRENT_EDITION_NAME') CURRENT_EDITION_NAME, 
      sys_context ('userenv','CURRENT_SCHEMA') CURRENT_SCHEMA, 
      sys_context ('userenv','CURRENT_SCHEMAID') CURRENT_SCHEMAID, 
      sys_context ('userenv','CURRENT_SQL') CURRENT_SQL, 
      sys_context ('userenv','CURRENT_SQLn') CURRENT_SQLn, 
      sys_context ('userenv','CURRENT_SQL_LENGTH') CURRENT_SQL_LENGTH, 
      sys_context ('userenv','CURRENT_USER') CURRENT_USER, 
      sys_context ('userenv','CURRENT_USERID') CURRENT_USERID, 
      sys_context ('userenv','DATABASE_ROLE') DATABASE_ROLE, 
      sys_context ('userenv','DB_DOMAIN') DB_DOMAIN, 
      sys_context ('userenv','DB_NAME') DB_NAME, 
      sys_context ('userenv','DB_UNIQUE_NAME') DB_UNIQUE_NAME, 
      sys_context ('userenv','DBLINK_INFO') DBLINK_INFO, 
      sys_context ('userenv','ENTRYID') ENTRYID, 
      sys_context ('userenv','ENTERPRISE_IDENTITY') ENTERPRISE_IDENTITY, 
      sys_context ('userenv','FG_JOB_ID') FG_JOB_ID, 
      sys_context ('userenv','GLOBAL_CONTEXT_MEMORY') GLOBAL_CONTEXT_MEMORY, 
      sys_context ('userenv','GLOBAL_UID') GLOBAL_UID, 
      sys_context ('userenv','HOST') HOST, 
      sys_context ('userenv','IDENTIFICATION_TYPE') IDENTIFICATION_TYPE, 
      sys_context ('userenv','INSTANCE') INSTANCE, 
      sys_context ('userenv','INSTANCE_NAME') INSTANCE_NAME, 
      sys_context ('userenv','IP_ADDRESS') IP_ADDRESS, 
      sys_context ('userenv','ISDBA') ISDBA, 
      sys_context ('userenv','LANG') LANG, 
      sys_context ('userenv','LANGUAGE') LANGUAGE, 
      sys_context ('userenv','MODULE') MODULE, 
      sys_context ('userenv','NETWORK_PROTOCOL') NETWORK_PROTOCOL, 
      sys_context ('userenv','NLS_CALENDAR') NLS_CALENDAR, 
      sys_context ('userenv','NLS_CURRENCY') NLS_CURRENCY, 
      sys_context ('userenv','NLS_DATE_FORMAT') NLS_DATE_FORMAT, 
      sys_context ('userenv','NLS_DATE_LANGUAGE') NLS_DATE_LANGUAGE, 
      sys_context ('userenv','NLS_SORT') NLS_SORT, 
      sys_context ('userenv','NLS_TERRITORY') NLS_TERRITORY, 
      sys_context ('userenv','OS_USER') OS_USER, 
      sys_context ('userenv','POLICY_INVOKER') POLICY_INVOKER, 
      sys_context ('userenv','PROXY_ENTERPRISE_IDENTITY') PROXY_ENTERPRISE_IDENTITY, 
      sys_context ('userenv','PROXY_USER') PROXY_USER, 
      sys_context ('userenv','PROXY_USERID') PROXY_USERID, 
      sys_context ('userenv','SERVER_HOST') SERVER_HOST, 
      sys_context ('userenv','SERVICE_NAME') SERVICE_NAME, 
      sys_context ('userenv','SESSION_EDITION_ID') SESSION_EDITION_ID, 
      sys_context ('userenv','SESSION_EDITION_NAME') SESSION_EDITION_NAME, 
      sys_context ('userenv','SESSION_USER') SESSION_USER, 
      sys_context ('userenv','SESSION_USERID') SESSION_USERID, 
      sys_context ('userenv','SESSIONID') SESSIONID, 
      sys_context ('userenv','SID') SID, 
      sys_context ('userenv','STATEMENTID') STATEMENTID, 
      sys_context ('userenv','TERMINAL') TERMINAL 
     from dual 
     -- where sys_context ('userenv','SESSIONID') NOT in ('SYS', 'XDB') -- <<<<< filter by user 
    ) 
     unpivot include nulls (
     val for name in (action, audited_cursorid, authenticated_identity, authentication_data, authentication_method, bg_job_id, client_identifier, client_info, current_bind, current_edition_id, current_edition_name, current_schema, current_schemaid, current_sql, current_sqln, current_sql_length, current_user, current_userid, database_role, db_domain, db_name, db_unique_name, dblink_info, entryid, enterprise_identity, fg_job_id, global_context_memory, global_uid, host, identification_type, instance, instance_name, ip_address, isdba, lang, language, module, network_protocol, nls_calendar, nls_currency, nls_date_format, nls_date_language, nls_sort, nls_territory, os_user, policy_invoker, proxy_enterprise_identity, proxy_user, proxy_userid, server_host, service_name, session_edition_id, session_edition_name, session_user, session_userid, sessionid, sid, statementid, terminal) 
    ) 
    ) res; 
Cuestiones relacionadas