虚拟专用数据库概述

发布时间:2016-11-28 00:00:00 编辑:嘉辉 手机版

  虚拟专用数据库是一项重要技术,使企业能够构建托管的、基于 Web 的应用程序。实际上,许多 Oracle 应用程序本身使用 VPD 实施数据分隔,包括 Oracle SalesOnline.com 和 Oracle Portal 等程序。下面小编为大家整理了关于虚拟专用数据库概述的文章,希望能为你提供帮助:

  概述

  虚拟专用数据库 (VPD) 提供了角色和视图无法提供的行级访问控制。对于互联网访问,虚拟专用数据库可以确保在线银行的客户只能看到他们自己的帐户。Web 托管公司可以在同一 Oracle 数据库中维护多个公司的数据,但只允许每个公司查看其自身数据。

  在企业内部,虚拟数据库可在应用程序部署方面降低拥有成本。可以在数据库服务器一次实现安全性,而不用在访问数据的每个应用程序中分别实现安全性。因为是在数据库中实施安全性,所以不管用户访问数据的方式如何,安全性较以前更高。访问即席查询工具或新报表生成程序的用户不再能绕过安全环节。虚拟专用数据库是一项重要技术,使企业能够构建托管的、基于 Web 的应用程序。实际上,许多 Oracle 应用程序本身使用 VPD 实施数据分隔,包括 Oracle SalesOnline.com 和 Oracle Portal 等程序。

  虚拟专用数据库如何工作

  将一个或多个安全策略与表或视图关联后,就可以实现虚拟专用数据库。对带安全策略的表进行直接或间接访问时,数据库将调用一个实施该策略的函数。策略函数返回一个访问条件(WHERE 子句),即谓词。应用程序将它附加到用户的 SQL 语句,从而动态修改用户的数据访问权限。

  你可以通过编写一个存储过程将 SQL 谓词附加到每个 SQL 语句(用于控制该语句的行级别访问权限)来实施 VPD。例如,如果 John Doe(他属于 Department 10)输入 SELECT * FROM emp 语句,则可以使用 VPD 添加 WHERE DEPT = 10 子句。这样,您便可以通过对查询进行修改

  案例说明

  1. 搭建环境--创建模式拥有者和相应的用户,赋予权限

  view plaincopy to clipboardprint?

  CONNECT sys/password@service AS SYSDBA;

  CREATE USER schemaowner IDENTIFIED BY schemaowner

  DEFAULT TABLESPACE users TEMPORARY TABLESPACE temp;

  GRANT connect, resource TO schemaowner;

  CREATE USER user1 IDENTIFIED BY user1

  DEFAULT TABLESPACE users TEMPORARY TABLESPACE temp;

  GRANT connect, resource TO user1;

  CREATE USER user2 IDENTIFIED BY user2

  DEFAULT TABLESPACE users TEMPORARY TABLESPACE temp;

  GRANT connect, resource TO user2;

  GRANT EXECUTE ON DBMS_RLS TO PUBLIC;

  CONN schemaowner/schemaowner@service

  CREATE TABLE users

  (id NUMBER(10) NOT NULL,

  ouser VARCHAR2(30) NOT NULL,

  first_name VARCHAR2(50) NOT NULL,

  last_name VARCHAR2(50) NOT NULL);

  CREATE TABLE user_data

  (column1 VARCHAR2(50) NOT NULL,

  user_id NUMBER(10) NOT NULL);

  INSERT INTO users VALUES (1,'USER1','User','One');

  INSERT INTO users VALUES (2,'USER2','User','Two');

  COMMIT;

  GRANT SELECT, INSERT ON user_data TO user1, user2

  CONNECT sys/password@service AS SYSDBA;

  CREATE USER schemaowner IDENTIFIED BY schemaowner

  DEFAULT TABLESPACE users TEMPORARY TABLESPACE temp;

  GRANT connect, resource TO schemaowner;

  CREATE USER user1 IDENTIFIED BY user1

  DEFAULT TABLESPACE users TEMPORARY TABLESPACE temp;

  GRANT connect, resource TO user1;

  CREATE USER user2 IDENTIFIED BY user2

  DEFAULT TABLESPACE users TEMPORARY TABLESPACE temp;

  GRANT connect, resource TO user2;

  GRANT EXECUTE ON DBMS_RLS TO PUBLIC;

本文已影响863
+1
0