使用多版本化视图读取 PostgreSQL 中已版本化的数据
可以对多版本化视图执行 SQL SELECT 语句以访问版本化数据。
多版本化视图将自动访问 DEFAULT 版本。在对视图发出任何查询之前,必须确保您将查询所需的版本。
要访问默认版本之外的特定版本,可执行 ArcSDE sde_set_current_version 函数。此过程将验证所提供的版本名称并在内部设置相应的数据库状态。可以从 SQL 客户端直接执行该过程。用于设置当前版本的函数的语法如下:
SELECT sde.sde_set_current_version('<version_name>');
如果需要更改为其他版本,可以再次调用此过程。每当工作空间刷新时都可调用此过程,以便将版本化表的当前状态返回到调用应用程序。
警告:
不应将多版本化视图用于访问或修改复杂要素(例如,参与几何网络、拓扑、terrain、地籍结构、网络数据集或关系的要素,或具有特定地理数据库行为的要素)。应使用 ArcGIS 来查看和修改这些类型的要素。
步骤:
-
在 MS-DOS (Windows) 或 shell (Linux) 命令提示符处,执行 sdetable 工具以创建多版本化视图。
sdetable –o create_mv_view –T code_mv –t code_enf –i sde:postgresql:myserver –D code –u sarja –p not4U
-
打开 psql 客户端并使用 sde_set_current_version 过程来设置要编辑的版本。
SELECT sde.sde_set_current_version('version2');
-
对多版本化视图发出 SELECT 语句以便从地理数据库中读取版本化数据。
SELECT violationID,codenum,propowner,insp_date FROM code_mv WHERE zip = '99999';
相关主题
3/7/2012