Oracle 10g 特性之虚拟专用数据库
创始人
2024-07-24 11:41:27
0

导读: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的配置方法

 

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...