Oracle中获取会话信息的两个函数分享

 更新时间:2014年12月20日 14:58:06   投稿:junjie  
这篇文章主要介绍了Oracle中获取会话信息的两个函数分享,本文分别讲解了USERENV和两个函数sys_context,并对可以获取哪些信息作了介绍,需要的朋友可以参考下

1、 USERENV(OPTION) 
  返回当前的会话信息. 
  OPTION='ISDBA'若当前是DBA角色,则为TRUE,否则FALSE. 
  OPTION='LANGUAGE'返回数据库的字符集. 
  OPTION='SESSIONID'为当前会话标识符. 
  OPTION='ENTRYID'返回可审计的会话标识符. 
  OPTION='LANG'返回会话语言名称的ISO简记. 
  OPTION='INSTANCE'返回当前的实例. 
    OPTION='terminal'返回当前计算机名 
  SELECT USERENV('LANGUAGE') FROM DUAL;
2、sys_context

复制代码 代码如下:

select  
SYS_CONTEXT('USERENV','TERMINAL') terminal,  
SYS_CONTEXT('USERENV','LANGUAGE') language,  
SYS_CONTEXT('USERENV','SESSIONID') sessionid,  
SYS_CONTEXT('USERENV','INSTANCE') instance,  
SYS_CONTEXT('USERENV','ENTRYID') entryid,  
SYS_CONTEXT('USERENV','ISDBA') isdba,  
SYS_CONTEXT('USERENV','NLS_TERRITORY') nls_territory,  
SYS_CONTEXT('USERENV','NLS_CURRENCY') nls_currency,  
SYS_CONTEXT('USERENV','NLS_CALENDAR') nls_calendar,  
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','CURRENT_USER') current_user,  
SYS_CONTEXT('USERENV','CURRENT_USERID') current_userid,  
SYS_CONTEXT('USERENV','SESSION_USER') session_user,  
SYS_CONTEXT('USERENV','SESSION_USERID') session_userid,  
SYS_CONTEXT('USERENV','PROXY_USER') proxy_user,  
SYS_CONTEXT('USERENV','PROXY_USERID') proxy_userid,  
SYS_CONTEXT('USERENV','DB_DOMAIN') db_domain,  
SYS_CONTEXT('USERENV','DB_NAME') db_name,  
SYS_CONTEXT('USERENV','HOST') host,  
SYS_CONTEXT('USERENV','OS_USER') os_user,  
SYS_CONTEXT('USERENV','EXTERNAL_NAME') external_name,  
SYS_CONTEXT('USERENV','IP_ADDRESS') ip_address,  
SYS_CONTEXT('USERENV','NETWORK_PROTOCOL') network_protocol,  
SYS_CONTEXT('USERENV','BG_JOB_ID') bg_job_id,  
SYS_CONTEXT('USERENV','FG_JOB_ID') fg_job_id,  
SYS_CONTEXT('USERENV','AUTHENTICATION_TYPE') authentication_type,  
SYS_CONTEXT('USERENV','AUTHENTICATION_DATA') authentication_data  
from dual

3.与系统视图v$session组合使用可以获得更多信息(客户端所使用的应用程序等)
复制代码 代码如下:

select *
  from v$session se,
       (select SYS_CONTEXT('USERENV', 'TERMINAL') terminal,
               SYS_CONTEXT('USERENV', 'LANGUAGE') language,
               SYS_CONTEXT('USERENV', 'SESSIONID') sessionid,
               SYS_CONTEXT('USERENV', 'INSTANCE') instance,
               SYS_CONTEXT('USERENV', 'ENTRYID') entryid,
               SYS_CONTEXT('USERENV', 'ISDBA') isdba,
               SYS_CONTEXT('USERENV', 'NLS_TERRITORY') nls_territory,
               SYS_CONTEXT('USERENV', 'NLS_CURRENCY') nls_currency,
               SYS_CONTEXT('USERENV', 'NLS_CALENDAR') nls_calendar,
               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', 'CURRENT_USER') current_user,
               SYS_CONTEXT('USERENV', 'CURRENT_USERID') current_userid,
               SYS_CONTEXT('USERENV', 'SESSION_USER') session_user,
               SYS_CONTEXT('USERENV', 'SESSION_USERID') session_userid,
               SYS_CONTEXT('USERENV', 'PROXY_USER') proxy_user,
               SYS_CONTEXT('USERENV', 'PROXY_USERID') proxy_userid,
               SYS_CONTEXT('USERENV', 'DB_DOMAIN') db_domain,
               SYS_CONTEXT('USERENV', 'DB_NAME') db_name,
               SYS_CONTEXT('USERENV', 'HOST') host,
               SYS_CONTEXT('USERENV', 'OS_USER') os_user,
               SYS_CONTEXT('USERENV', 'EXTERNAL_NAME') external_name,
               SYS_CONTEXT('USERENV', 'IP_ADDRESS') ip_address,
               SYS_CONTEXT('USERENV', 'NETWORK_PROTOCOL') network_protocol,
               SYS_CONTEXT('USERENV', 'BG_JOB_ID') bg_job_id,
               SYS_CONTEXT('USERENV', 'FG_JOB_ID') fg_job_id,
               SYS_CONTEXT('USERENV', 'AUTHENTICATION_TYPE') authentication_type,
               SYS_CONTEXT('USERENV', 'AUTHENTICATION_DATA') authentication_data
          from dual) base
 where se.AUDSID = base.sessionid;
 

相关文章

  • Oracle 创建主键自增表示例代码

    Oracle 创建主键自增表示例代码

    我们经常在设计数据库的时候用一个系统自动分配的ID来作为我们的主键,但是在Oracle没有自增主键的设置,我们可以通过这篇文章介绍的方法实现,有需要的朋友们可以参考借鉴,下面来一起看看吧。
    2016-10-10
  • oracle 触发器 学习笔记

    oracle 触发器 学习笔记

    触发器 是特定事件出现的时候,自动执行的代码块。类似于存储过程,但是用户不能直接调用他们。
    2009-05-05
  • Oracle查询用户拥有所有系统权限的方法

    Oracle查询用户拥有所有系统权限的方法

    这篇文章主要介绍了Oracle查询用户拥有所有系统权限,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧
    2024-12-12
  • Oracle数据库scott用户创建view视图权限的操作方法

    Oracle数据库scott用户创建view视图权限的操作方法

    这篇文章主要介绍了Oracle数据库scott用户创建view视图权限的操作方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-01-01
  • 从Oracle数据库中读取数据自动生成INSERT语句的方法

    从Oracle数据库中读取数据自动生成INSERT语句的方法

    今天小编就为大家分享一篇关于从Oracle数据库中读取数据自动生成INSERT语句的方法,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-04-04
  • Oracle使用强制索引的方法与注意事项

    Oracle使用强制索引的方法与注意事项

    这篇文章主要给大家介绍了关于Oracle使用强制索引的方法与注意事项,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。
    2017-11-11
  • oracle数据库中listagg函数使用详解

    oracle数据库中listagg函数使用详解

    listagg函数是Oracle数据库中的一个聚合函数,用于将一组值连接成一个以指定分隔符分隔的字符串,这篇文章主要给大家介绍了关于oracle数据库中listagg函数使用的相关资料,需要的朋友可以参考下
    2024-06-06
  • Oracle 多参数查询语句

    Oracle 多参数查询语句

    这篇文章主要介绍了Oracle 多参数查询语句 的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2016-12-12
  • 清除Oracle数据库安装记录并重新安装

    清除Oracle数据库安装记录并重新安装

    这篇文章介绍了清除Oracle数据库安装记录并重新安装的方法,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-04-04
  • oracle去除空格的三种方式举例总结

    oracle去除空格的三种方式举例总结

    这篇文章主要介绍了oracle去除空格的三种方式,分别是使用TRIM()函数去除字符串两端空格,使用REPLACE()函数替换掉所有空格,以及利用REPLACE()结合CHR()函数去除制表符、换行符、回车符和空格符,这些方法帮助优化字符串处理,需要的朋友可以参考下
    2024-11-11

最新评论