Resumen
Migra una clase de relación basada en ObjectID a una clase de relación basada en GlobalID.
Uso
Esta herramienta modifica una clase de relación existente basada en ObjectID y la convierte en una clase de relación basada en GlobalID para cumplir con los requisitos de la geodatabase en tiempo de ejecución.
La clase de entidad o la tabla de origen que participa en la Clase de relación de entrada debe contener un campo GlobalID antes de usar la herramienta. La clase de destino también debe tener un campo de GlobalID.
La clase de relación de entrada existente debe estar basada en ObjectID. Es posible que los datos no puedan tener el archivado habilitado.
Esta herramienta admite editar datos versionados y no versionados como entrada.
Las clases de relación de anotación vinculada a entidad no se admiten como entrada para esta herramienta, ya que estas relaciones deben permanecer basadas en ObjectID.
Se recomienda tener una copia de seguridad de los datos utilizados como entrada para esta herramienta.
Sintaxis
MigrateRelationshipClass_management (in_relationship_class)
Parámetro | Explicación | Tipo de datos |
in_relationship_class | Clase de relación basada en ObjectID que se migrará a una clase de relación basada en GlobalID. Las tablas de clases de entidades de origen y de destino ya deben disponer de GlobalID. | Relationship Class |
Ejemplo de código
Ejemplo 1 de MigrateRelationshipClass (ventana de Python)
La siguiente secuencia de comandos de la ventana de Python muestra cómo utilizar la herramienta MigrateRelationshipClass en el modo inmediato.
arcpy.MigrateRelationshipClass_management(r'C:\Data\Relationships.gdb\OneToMany')
Ejemplo 2 de MigrateRelationshipClass (secuencia de comandos independiente)
La siguiente secuencia de comandos de Python independiente muestra cómo utilizar la herramienta MigrateRelationshipClass en una secuencia de comandos independiente.
# Name: MigrateRelationshipClass_Example.py
# Description: Migrate an ObjectID-based relationship class to a GlobalID-based
# relationship class. This script lists the ObjectID-based relationships classes
# in a workspace, checks for GlobalIDs in the origin, then runs the tool
# Import system modules
import arcpy
# Set local variables
workspace = r'C:\Data\Relationships.gdb'
# List all of the relationship classes within the given workspace
rc_list = [c.name for c in arcpy.Describe(workspace).children if c.datatype == "RelationshipClass"]
# Build a list of relationship classes which have an OBJECTID based origin class key
rc_migrate = []
for rc in rc_list:
rc_path = workspace + "\\" + rc
rc_desc = arcpy.Describe(rc_path)
for item in rc_desc.OriginClassKeys:
if "OBJECTID" in item:
rc_migrate.append(rc_path)
# Check that the origin feature classes have Global Ids
rc_final = []
for rel in rc_migrate:
originfc = workspace + "\\" + arcpy.Describe(rel).originClassNames[0]
if arcpy.ListFields(originfc,"","GlobalID"):
rc_final.append(rel)
print("Adding {0} to the list to migrate. \n".format(rel.rsplit("\\",1)[1]))
else:
print("{0} must have Global Ids to migrate relationship class.\n".format(originfc.rsplit("\\",1)[1]))
# Pass the list of valid relationship classes into the Migrate Relationship tool
print("Passing valid relationship classes into the Migrate Relationship Class tool.\n")
for rel_class in rc_final:
print("Migrating {0}... \n".format(rel_class.rsplit("\\",1)[1]))
arcpy.MigrateRelationshipClass_management(rel_class)
print(arcpy.GetMessages() + "\n")
Entornos
Información sobre licencias
- ArcGIS for Desktop Basic: No
- ArcGIS for Desktop Standard: Sí
- ArcGIS for Desktop Advanced: Sí