摘要
根据目标版本协调一个或多个版本。
用法
协调过程要求您是当前正在编辑版本的唯一用户,并且是整个协调过程中(直到执行保存或提交操作为止)能够编辑版本的唯一用户。
协调过程要求您对正在编辑的版本中的所有已修改要素类具有全部权限。
版本管理工具仅适用于企业级 (ArcSDE) 地理数据库。文件和个人地理数据库不支持版本管理。
地理数据库用于高效管理和支持使用版本的长事务。
协调过程将检测到编辑版本与目标版本之间的差异,然后将这些差异标记为冲突。如果存在冲突,则应将其解决。
使用“ALL_VERSIONS”选项成功运行协调过程后,地理数据库中的所有版本都会变为相同版本。
语法
ReconcileVersions_management (input_database, reconcile_mode, {target_version}, {edit_versions}, {acquire_locks}, {abort_if_conflicts}, {conflict_definition}, {conflict_resolution}, {with_post}, {with_delete}, {out_log})
参数 | 说明 | 数据类型 |
input_database | 包含要协调的版本的企业级地理数据库。默认情况下,使用在环境中定义的工作空间。 | Workspace |
reconcile_mode | 确定执行工具时要协调的版本。
| String |
target_version (可选) | 编辑版本的任何直系版本的名称,例如父版本或默认版本。 通常包含其他版本的编辑内容,用户执行协调后这些内容将放入其编辑版本中。 | String |
edit_versions [edit_versions,...] (可选) | 要与所选目标版本进行协调的编辑版本的名称。可以是单个版本名称或版本名称的 Python 列表。 | String |
acquire_locks (可选) | 确定是否将获取要素锁定。
| Boolean |
abort_if_conflicts (可选) | 如果在目标版本与编辑版本之间发现冲突,则确定是否应中止协调过程。
| Boolean |
conflict_definition (可选) | 描述发生冲突所需的条件:
| String |
conflict_resolution (可选) | 描述检测到冲突时的行为:
| String |
with_post (可选) | 将当前编辑会话提交到已协调的目标版本。
| Boolean |
with_delete (可选) |
| Boolean |
out_log (可选) | 指定名称和写入日志文件的位置。日志文件为包含地理处理消息内容的 ASCII 文件。 | File |
代码实例
协调版本 (ReconcileVersions) 示例(独立脚本):
以下独立脚本演示了如何使用 ReconcileVersions 工具协调在 SDE 连接文件中指定的用户所拥有的所有版本。
# Name: ReconcileVersions.py
# Description: Reconciles all versions owned by a user with SDE.Default
# Import system modules
import arcpy, os
# Set workspace
workspace = 'C:/Data/connections/bender@production.sde'
# Set the workspace environment
arcpy.env.workspace = workspace
# Use a list comprehension to get a list of version names where the owner
# is the current user and make sure sde.default is not selected.
verList = [ver.name for ver in arcpy.da.ListVersions() if ver.isOwner
== True and ver.name.lower() != 'sde.default']
arcpy.ReconcileVersions_management(workspace,
"ALL_VERSIONS",
"SDE.Default",
verList,
"LOCK_ACQUIRED",
"NO_ABORT",
"BY_OBJECT",
"FAVOR_TARGET_VERSION",
"NO_POST",
"KEEP_VERSION",
"c:\RecLog.txt")
print('Reconciling Complete')