Oracle 10g 特性之虚拟专用数据库

数据库 Oracle
虚拟专用数据库 (VPD) 也称为细粒度访问控制,它提供强大的行级安全功能。它是在Oracle8i中推出的,已经受到广泛的欢迎,并且在从教育软件到金融服务等各种应用程序得到采用。Oracle 10g 也是功能性比较强大的。

导读:Oracle 10g的可用性较之前的版本有很大程度的提高。虚拟专用数据库的工作方法是,通过透明地更改对数据的请求,基于一系列定义的标准向用户提供表的局部视图。在运行时,所有查询都附加了谓词,以便筛选出准许用户看到的行。例如,如果只允许用户查看帐户管理员SCOTT的帐户,则 VPD 设置自动地将查询:

  select * from accounts;

  重写为:

  select * from accounts

  where am_name = "SCOTT";

  DBA 在表 ACCOUNTS 上设置了一项安全策略。该策略具有一个相关函数,称为policyn,它返回一个用作谓词的字符串where am_name = "SCOTT"。如果您不熟悉该特性的全部功能,我建议您阅读 Oracle杂志的文章“利用 VPD保持信息的私密性”。

  策略类型

  生成谓词所需的重复分析是一种在某些情况下可以进行修整的开销。例如,在大部分实际情况中,谓词并不象 am_name="SCOTT"那样是静态的;它基于用户的身份、用户的权限级别、用户向哪个帐户管理员进行报告等情况,可能更具有动态性。由策略函数创建并返回的字符串可能会具有很强的动态性,而为了保证其结果,Oracle必须每次重新执行策略函数,既浪费资源又降低性能。在这种类型的策略中,谓词每次执行时可能会有很大的差别,该策略称为“动态”策略,在Oracle9i数据库以及以前的版本中已经提供了这种策略。

  除了保留动态策略之外,Oracle 数据库10g还基于谓词的构造推出了几种新类型的策略,为提高性能提供了更好的控制:context_sensitive、shared_context_sensitive、shared_static和static。现在,让我们来了解每种策略类型的意义以及如何在适当的场合中使用它们。

  动态策略。 为保持向后兼容性,10g 中的默认策略类型为“dynamic” — 正如Oracle9i中一样。在这种情况下,对于每行以及每位用户,在每次访问表时都对策略函数进行重新求值。让我们来详细分析策略谓词:

  where am_name = "SCOTT"

  忽略掉 where 子句,谓词就具有两个不同的部分:在等式操作符之前的部分 (am_name)和等式操作符之后的部分("SCOTT")。在大多数情况下,后面的部分更象是变量,因为它是由用户的数据提供的(如果用户是SCOTT,则其值为"SCOTT")。在等号前面的部分是静态的。因此,即使函数不必为生成适当的谓词而对每行求出策略函数的值,由于了解前面部分的静态性以及后面部分的动态性,也可以提高性能。在10g中,可以在 dbms_rls.add_policy 调用中使用"context_sensitive"类型的策略作为参数来实现这种方法。

很高兴与大家分享,希望上文中讲到的内容对大家能够有所帮助。

【编辑推荐】

  1. 在Oracle数据库10g中跟踪SQL
  2. 详解RedHat AS5下安装Oracle 10g数据库
  3. 透过SQL Server 2008访问Oracle 10g的配置方法

 

责任编辑:迎迎 来源: IT专家网
相关推荐

2009-11-19 15:57:34

Oracle 10g数

2010-02-03 16:16:49

Linux Oracl

2011-03-29 09:56:48

Oracle数据库10SQL

2011-08-09 18:15:24

Oracle 10g查找数据

2010-09-17 09:39:31

Oracle 10g

2010-04-16 15:57:54

Oracle 10g

2010-04-12 13:34:42

Oracle 10g

2011-08-09 13:14:37

Oracle 10g数据库闪回

2011-08-24 09:56:07

Oracle hand虚拟专用数据库VPD

2010-04-13 10:07:19

Oracle 10G

2009-10-20 18:32:25

Oracle 10g

2011-07-05 16:18:14

DataGuardSTANDBY

2010-05-05 15:52:36

Oracle 10G

2011-08-30 15:57:15

Oracle 10gUNDO_RETENT

2009-01-20 23:13:24

Oracle 10G数据库

2010-04-14 16:09:51

Oracle 10g归

2010-04-09 15:59:24

Oracle 10g

2010-02-22 14:03:59

2010-04-07 09:39:18

Oracle 10G

2011-08-17 13:37:27

Windows7卸载Oracle 10
点赞
收藏

51CTO技术栈公众号