使用多版本化视图读取 DB2 中已版本化的数据

可以对多版本化视图执行 SQL SELECT 语句以访问版本化数据。

注注:

z 操作系统上的 IBM DB2 数据库中不支持多版本化视图。

多版本化视图将自动访问 DEFAULT 版本。在对视图发出任何查询之前,必须确保您将查询所需的版本。

要访问默认版本之外的特定版本,请执行 ArcSDE setcurrentversion 存储过程。此过程将验证所提供的版本名称并在内部设置相应的数据库状态。可以从 SQL 客户端直接执行该过程。用于设置当前版本的存储过程的语法如下:

CALL sde.setcurrentversion('<version_name>',?,?)

如果需要更改为其他版本,可以再次调用此过程。每当工作空间刷新时都可调用此过程,以便将版本化表的当前状态返回到调用应用程序。

警告警告:

不应将多版本化视图用于访问或修改复杂要素(例如,参与几何网络、拓扑、terrain、地籍结构、网络数据集或关系的要素,或具有特定地理数据库行为的要素)。应使用 ArcGIS 来查看和修改这些类型的要素。

步骤:
  1. 在 MS-DOS (Windows) 或 shell(UNIX 或 Linux)命令提示符处,执行 sdetable 工具以创建多版本化视图。
    sdetable –o create_mv_view –T code_mv 
    –t code_enf –i sde:db2 –D code –u sarja –p not4U
  2. 打开 SQL 客户端并调用 setcurrentversion 存储过程以设置要编辑的版本。
    CALL sde.setcurrentversion('version2',?,?)

    两个问号分别表示 message_code_output 和 message_output。message_code_output 和 message_output 是执行该函数以后返回的 SQL 编码和消息。传入问号后将返回编码和消息。

  3. 对多版本化视图发出 SELECT 语句以便从地理数据库中读取版本化数据。
    SELECT owner, site_address, region
    FROM code_mv
    WHERE region = 'b'

相关主题


7/10/2012