Oracle创建上下文 SYS_CONTEXT

1. 系统默认的一些参数

set heading off
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;
-- 另一种展示方式
set serveroutput on
exec dbms_output.put_line(sys_context('USERENV','CURRENT_USER'));

2. 自定义上下文属性

create user king identified by king;
grant dba to king;
connect king/king
create table emp as select * from scott.emp;
create context emp_user using current_emp;

-- 创建包current_emp
CREATE OR REPLACE PACKAGE current_emp IS
PROCEDURE set_emp_info;
END;
/ CREATE OR REPLACE PACKAGE BODY current_emp IS
PROCEDURE set_emp_info IS
  v_sal     emp.sal%TYPE;
  v_job     emp.JOB%TYPE;
  v_hiredate emp.HIREDATE%TYPE;
 BEGIN
   SELECT sal, JOB, HIREDATE
     INTO v_sal, v_job, v_hiredate
     FROM emp
    WHERE ename = SYS_CONTEXT('USERENV', 'SESSION_USER');
 
  DBMS_SESSION.SET_CONTEXT('emp_user', 'sal', v_sal);
  DBMS_SESSION.SET_CONTEXT('emp_user', 'job', v_job);
  DBMS_SESSION.SET_CONTEXT('emp_user', 'hiredate', v_hiredate);
  DBMS_SESSION.SET_CONTEXT('emp_user', 'ename', SYS_CONTEXT('USERENV', 'SESSION_USER'));
EXCEPTION
  WHEN NO_DATA_FOUND THEN
     NULL;
END;
END;
/
​ -- 创建触发器
CREATE or REPLACE TRIGGER emp_logon
AFTER LOGON ON DATABASE
BEGIN
current_emp.set_emp_info;
END;
/

-- 验证
exit
sqlplus king/king
SET SERVEROUTPUT ON
EXEC dbms_output.put_line(sys_context('emp_user', 'SAL'));
EXEC dbms_output.put_line(sys_context('emp_user', 'job'));
EXEC dbms_output.put_line(sys_context('emp_user', 'hiredate'));
SELECT sys_context('emp_user', 'SAL') FROM DUAL;

--列出当前session 的所有上下文属性
sqlplus king/king

SET ECHO OFF
SET SERVEROUTPUT ON
DECLARE
list dbms_session.AppCtxTabTyp;
cnt number;
BEGIN
dbms_session.list_context(list, cnt);
IF cnt = 0 THEN
  dbms_output.put_line('No contexts active.');
ELSE
  FOR i IN 1 .. cnt LOOP
    dbms_output.put_line(list(i).namespace || ' ' || list(i).attribute ||
                           ' = ' || list(i).value);
  END LOOP;
END IF;
END;
/

--查询
SELECT *
FROM dba_context
WHERE namespace = 'EMP_USER';

参考

【诗檀学院】ORACLE 11g OCM考试学习材料-手动实操课程

Oracle创建上下文 SYS_CONTEXT的更多相关文章

  1. 利用Oracle创建表空间和用户

    本文仅用于学习交流,商业用途请支持正版!转载请注明:http://www.cnblogs.com/mxbs/p/6217152.html 第一步,创建表空间 以SYS/sys账户和SYSDBA身份登录 ...

  2. 利用Oracle创建数据库

    本文仅用于学习交流,商业用途请支持正版!转载请注明:http://www.cnblogs.com/mxbs/p/6217151.html 数据库的创建 打开"所有程序"-" ...

  3. Oracle创建数据库

    Oracle创建数据库有三种方式:一.使用DBCA(Database Configuration Assistant 数据库配置助手):二.使用 create database指令:三.在安装数据库软 ...

  4. oracle创建表之前判断表是否存在,如果存在则删除已有表

    Mysql 创建表之前判断表是否存在,如果存在则删除已有表 DROP TABLE IF EXISTS sys_area; CREATE TABLE sys_area ( id int NOT NULL ...

  5. oracle创建数据库和用户

    以前开发的时候用得比较多的是mysql和sql server,oracle用的比较少,用起来比较生疏,mysql和sql server用起来比较类似,就oracle的使用方式和他们不同,oracle在 ...

  6. ORACLE创建表空间、创建用户、更改用户默认表空间以及授权、查看权限

    Oracle创建用户.表空间.导入导出....命令 //创建临时表空间 create temporary tablespace ext_temptempfile 'D:\oracle\product\ ...

  7. Oracle创建表空间和表

    创建表空间和表ORACLE物理上是由磁盘上的以下几种文件:数据文件和控制文件和LOGFILE构成的oracle中的表就是一张存储数据的表.表空间是逻辑上的划分.方便管理的.数据表空间 (Tablesp ...

  8. Oracle创建自增字段方法-ORACLE SEQUENCE的简单介绍

    引用自 :http://www.2cto.com/database/201307/224836.html   Oracle创建自增字段方法-ORACLE SEQUENCE的简单介绍 先假设有这么一个表 ...

  9. Oracle创建用户并给用户授权查询指定表或视图的权限

    MSV31账户登录数据库进行如下操作: CREATE USER NORTHBOUND IDENTIFIED BY NORTHBOUND  DEFAULT TABLESPACE "TBS_DN ...

随机推荐

  1. 关于类似QQ的展开和折叠效果的实现

    介绍: 1.两级折叠与展开: 实现原理如下: 1>通过表视图的组的头视图和单元格实现; 2>通过改变cell的高度实现; 3>通过cell实现; 实现 UITableView 的ce ...

  2. Tools - Tcpdump

    Tcpdump homepage - tcpdump wiki - tcpdump 常用格式 tcpdump -i eth<网卡号> port <端口号> -s0 -w < ...

  3. 记录一下我的git连接不上GitHub问题

    1.日常操作,提交代码,报错误下: $ git clone git@github.com:hanchao5272/myreflect.git Cloning into 'myreflect'... s ...

  4. jquery-easyui中改变【确认框控件的按钮文字】($.messager.confirm)

    根据API这句话,就很自然想到重写该方法,代码如下: $.messager.defaults = { ok: "通过", cancel: "不通过" ,widt ...

  5. 写一个单独的qt模块 -- ongoing

    彩阳发的链接: https://wiki.qt.io/Creating_a_new_module_or_tool_for_Qt

  6. 图解JS

    弱语言 数据类型 隐式转换 弱等于 严格等于 包装对象 字符串转为包装对象 类型检测 表达式 运算符 块 try...catch 对象结构 创建对象,原型链 属性读写 getter,setter 序列 ...

  7. yii2中 选择布局的方式,可以设置不使用布局

    ###yii2中 选择布局的方式,可以设置不使用布局 控制器内成员变量 public $layout = false; //不使用布局 public $layout = "main" ...

  8. golang中switch用法细节

    1. switch穿透-fallthrough, 如果在case语句块后增加fallthrough,则会继续执行下一个case,也叫switch穿透,默认只穿透一层 2. Type Switch: s ...

  9. Vue解决项目白屏

    第一步:  vue-cli项目根目录下面新建Vue.config.js文件  proxy反向代理    module.exports = {   devServer: {     proxy: {   ...

  10. HTTP抓包

    1 概述 wireshark:全平台抓包工具,需要图形化界面,十分强大: httpry:http抓包插件,功能一般,操作简单: tcpdump:强大的抓包插件,支持多种网络协议. 2 httpry ( ...