Strategien für die Datenverwaltung

Transaktionen mit geographischen Daten können hinsichtlich der Dauer und Komplexität große Unterschiede aufweisen. Die Geodatabase unterstützt zwei Strategien für die Datenverwaltung: mit und ohne Versionen. So wird allen Anforderungen von Benutzern und Anwendungen für die Ausführung kurzer und langer Transaktionen mit einfachen oder komplexen Daten Rechnung getragen.

Die Strategien werden für jede Feature-Class bzw. jede Tabelle einzeln festgelegt. Daher können in einer Geodatabase beide Strategien eingesetzt werden.

Bei beiden Strategien werden die Daten auf ähnliche Art bearbeitet. In beiden Fällen arbeiten Sie in einer Editiersitzung und größtenteils außerdem mit den gleichen Werkzeugen. Unterschiede bestehen jedoch darin, wie die zu Grunde liegenden Datenquellen verwaltet werden. Zudem bestehen Unterschiede darin, welche Daten Sie bearbeiten und welche Art von Workflows Sie ausführen können. Diese Unterschiede werden in diesem Abschnitt erläutert.

Datenverwaltung ohne Versionen

Bei dieser Strategie wird nicht mit mehreren Versionen gearbeitet. Es wird einfach das Transaktionsmodell des zu Grunde liegenden DBMS verwendet. Eine Bearbeitung ohne Versionierung der Daten entspricht der Verwendung von regulären Datenbanktransaktionen.

Zum Bearbeiten der Daten aktivieren Sie im Dialogfeld Editieroptionen das nicht versionierte Bearbeiten. Starten Sie eine Editiersitzung, und führen Sie dann die erforderlichen Vorgänge aus, z. B. Hinzufügen, Löschen oder Verschieben von Features oder Aktualisieren von Attributen. Mit der ersten Bearbeitung in der Editiersitzung beginnt die Transaktion. Beim Speichern werden die einzelnen Bearbeitungsvorgänge zusammen als eine Transaktion in der Datenbank festgeschrieben. Nach dem Speichern wird mit der nächsten Bearbeitung eine neue Transaktion begonnen. Während einer Editiersitzung können Sie je nach Bedarf mehrere Vorgänge gleichzeitig speichern. Allerdings wird empfohlen, häufig zu speichern, damit die bearbeiteten Daten nicht gesperrt werden und der Zugriff auf die Daten oder deren Bearbeitung durch andere Benutzer nicht blockiert wird. Nachdem Sie die Änderungen gespeichert haben, stehen diese allen anderen Benutzern und Anwendungen, die auf die Daten zugreifen, zur Verfügung.

Wenn Sie die Bearbeitungen nicht in der Datenbank festschreiben möchten, beenden Sie die Editiersitzung ohne zu speichern. Alle Bearbeitungen in dieser Transaktion werden verworfen und nicht in der Datenbank festgeschrieben. Dies betrifft alle Bearbeitungen seit dem letzten Speichern oder, falls Sie in der Zwischenzeit nicht gespeichert haben, alle Bearbeitungen seit dem Beginn der Editiersitzung.

Datenverwaltung ohne Versionen

Beim Bearbeiten werden alle im DBMS für die Daten definierten eindeutigen Indizes, Einschränkungen und Trigger angewendet. Das Sperrverhalten wird so angewendet, als würden Sie direkt im DBMS Datentransaktionen durchführen. Daher besteht für Benutzer oder Anwendungen, die auf dieselben Daten zugreifen oder diese ändern, die Gefahr, sich gegenseitig zu blockieren. Wenn mehrere Benutzer gleichzeitig nicht versionierte Daten bearbeiten, sollten Sie mit der Funktionsweise von Isolierungsgraden und Sperren im DBMS vertraut sein und bei Bedarf den richtigen Isolationsgrad im DBMS festlegen, bevor Sie mit ArcGIS arbeiten.

Diese Strategie ist für einfache Features geeignet, für die weder der Verlauf noch mehrere Repräsentationen der Daten mit Versionen verwaltet werden müssen. Da für diese Strategie keine Versionen erforderlich sind, ist es sowohl bei GIS- als auch bei anderen Anwendungen vorteilhaft, auf eine gemeinsame Datenbank zuzugreifen.

Potenzielle Anwendungsbereiche

Einschränkungen

Datenverwaltung mit Versionen

Durch eine Geodatabase wird der reguläre DBMS-Transaktionsmechanismus erweitert, indem gleichzeitig mehrere Datenbankzustände zugelassen werden. Diese werden als Versionen bezeichnet. Jede Version kann laufende Vorgänge darstellen, z. B. einen Entwurf oder eine Gruppe von Arbeitsaufträgen – Arbeit, die sich über mehrere Verbindungen und über einen Zeitraum von Wochen oder Monaten erstrecken kann. Versionen ermöglichen das Verwalten früherer, aktueller und vorgeschlagener Änderungen an den Daten in derselben Geodatabase.

Um frühere Änderungen zu verwalten, speichern Sie sämtliche Änderungen an den Daten in separaten Archivtabellen. Sie können diese Änderungen so lange wie erforderlich aufbewahren. Dies ermöglicht es den Benutzern, den Zustand der Datenbank zu einem vergangenen Zeitpunkt einzusehen. Diese Funktion wird als Archivierung bezeichnet und ist in ArcGIS integriert. Es ist keine weitere Entwicklung erforderlich. Wenn Sie diese Funktion aktivieren, werden Änderungen an der DEFAULT-Version, die normalerweise als veröffentlichte Version der Datenbank verwendet wird, automatisch archiviert.

Um aktuelle Änderungen zu verwalten, können Bearbeiter ihre private Version der Geodatabase bearbeiten, um zu verhindern, dass andere Benutzer die laufenden Arbeiten einsehen können. Wenn Sie eine Version der Daten bearbeiten, werden keine Sperren gesetzt. Da andere Benutzer somit dieselben Daten lesen und bearbeiten können, die Sie bearbeiten, blockieren die Benutzer den Zugriff auf die Datenbank nicht gegenseitig, und die Nebenläufigkeit wird maximiert. Wenn ein Bearbeiter die Änderungen abgeschlossen hat, kann er oder sie diese in die veröffentliche Version integrieren.

Um vorgeschlagene Änderungen zu verwalten, können Sie ein Szenario entwickeln oder eine Was-wäre-wenn-Analyse innerhalb einer Version der Datenbank ausführen. Das Szenario kann als einzelne Änderung verwaltet werden, die sich über mehrere Editiersitzungen und Tage, Wochen oder Monate erstreckt. Sie können uneingeschränkt vorgeschlagene Features hinzufügen, geographische Analysen durchführen und Karten erstellen, ohne dass sich dies auf die Datenbank auswirkt, auf die andere Benutzer zugreifen. Wenn die Änderungen vollständig sind und genehmigt wurden, können Sie diese in den restlichen Teil der Geodatabase integrieren.

Mit Versionen können Sie frühere, aktuelle und vorgeschlagene Änderungen verwalten.

Eine Geodatabase kann beliebig viele Versionen aufweisen. Die Versionen können in verschiedenen Konfigurationen vorliegen und viele verschiedene Workflows unterstützen. Um die Einfachheit sicherzustellen und Geodatabase-Verwaltungsaspekte zu berücksichtigen, besteht die empfohlene bewährte Vorgehensweise jedoch darin, entweder eine flache Versionsstruktur zu verwenden oder für die Bearbeitung der DEFAULT-Version mehrere Editoren gleichzeitig zu verwenden.

Eine Geodatabase kann zahlreiche Versionen aufweisen

Zur Unterstützung der Versionierungsfunktionen werden Daten in ArcGIS nicht dupliziert. Stattdessen wird jede Feature-Class und Tabelle im ursprünglichen Format belassen, und alle Änderungen werden in Tabellen erfasst, die als Delta-Tabellen bezeichnet werden. Delta-Tabellen bestehen aus einer Adds-Tabelle für Einfügungen und Aktualisierungen sowie aus einer Deletes-Tabelle für Löschungen. Jedes Mal, wenn ein Datensatz in einer der Versionen aktualisiert oder gelöscht wird, werden einer oder beiden Tabellen Zeilen hinzugefügt. Wenn Sie eine Feature-Class oder Tabelle in einer Version abfragen oder anzeigen, fasst ArcGIS die relevanten Zeilen aus den Delta-Tabellen und der ursprünglichen Tabelle zusammen, um eine nahtlose Ansicht der Daten darzustellen.

Delta-Tabellen
Bearbeiten einer versionierten Feature-Class

Versionierte Tabellen erfordern die regelmäßige Wartung durch einen Datenbankadministrator. Wenn eine Geodatabase über einen Zeitraum hinweg bearbeitet wird, erhöhen sich die Größe der Delta-Tabellen, was sich auf die Darstellungs- und Abfrage-Performance auswirkt. Um die Datenbank-Performance aufrechtzuerhalten, müssen Datenbankadministratoren versionierte Datenbanken in regelmäßigen Abständen komprimieren, wobei redundante Informationen aus den Delta-Tabellen entfernt werden. Versionierte Datenbanken sollten nach einer Zeit hoher Datenbankaktivität komprimiert werden, z. B. am Ende einer Schicht oder nach dem Laden von Daten. Der Komprimierungsvorgang kann ausgeführt werden, wenn andere Benutzer verbunden sind und die Datenbank verwenden.

Mit ArcGIS können die den Versionen zugrunde liegenden Delta-Tabellen auf eine der folgenden Arten verwaltet werden:

Die erste Möglichkeit ist ausschließlich zur Unterstützung von ArcGIS-Anwendungen vorgesehen. Die zweite Möglichkeit ist nützlich, wenn Sie die Daten mit ArcGIS-Anwendungen und Anwendungen von Drittanbietern verwalten müssen.

Verwalten der Daten ausschließlich mit ArcGIS-Anwendungen

In einer Umgebung, in der Sie Daten ausschließlich mit ArcGIS-Anwendungen verwalten, empfiehlt sich eine Versionsverwaltung, bei der alle Änderungen in den Delta-Tabellen gespeichert werden. So können Sie die Funktionen der Geodatabase wie die Archivierung und Replikation sowie die Möglichkeit, geometrische Netzwerke und Topologien zu bearbeiten, optimal nutzen.

Um dieses Verhalten für eine Feature-Class oder Tabelle zu aktivieren, registrieren Sie die Daten als versioniert ohne die Option, die Änderungen in die Basistabelle zu verschieben. Wenn Sie Änderungen an einem auf diese Art registrierten Dataset speichern, werden Änderungen in den Delta-Tabellen gespeichert. Bei diesem Ansatz ist kein direkter Zugriff auf die ursprünglichen Tabellen möglich – die Benutzer greifen stets auf eine Version der Daten zu.

Im folgenden Beispiel wird eine Konfiguration veranschaulicht, in der Daten vollständig unter Verwendung von Versionen verwaltet werden. Die Bearbeiter müssen ArcGIS oder eine andere Esri Anwendung verwenden, um Änderungen an den Daten vornehmen zu können. Nicht-GIS-Anwendungen können auf die veröffentlichte Version oder eine andere Version zugreifen, sofern sie an versionierte Ansichten angepasst wurden.

Verwalten der Daten ausschließlich mit ArcGIS-Anwendungen

Da Delta-Tabellen und andere Tabellen Unterstützung für Versionen bieten müssen, haben Anwendungen, die ohne Esri Softwarebibliotheken direkt auf die Daten im DBMS zugreifen, nicht die entsprechenden Funktionen zum Lesen der Versionen. ArcGIS bietet versionierte Ansichten, sodass diese Anwendungen Versionen mit SQL lesen können. Mit versionierten Ansichten können Sie sowohl auf Tabellen als auch auf Feature-Classes zugreifen. Für den Zugriff auf die geometrischen Attribute von Feature-Classes in einer versionierten Ansicht müssen SQL-Geometrietypen verwendet werden. Diese werden von ArcGIS vollständig unterstützt.

Diese Vorgehensweise bietet folgende Vorteile:

Mögliche Anwendungen schließen die folgenden ein:

Versionen bieten viele Vorteile, weisen jedoch auch einige Einschränkungen auf:

Verwalten von Daten mit ArcGIS- und anderen Anwendungen

In einer heterogenen Computerumgebung, wo verschiedene Abteilungsanwendungen auf dieselbe Datenbank zugreifen, ist möglicherweise die Unterstützung von ArcGIS und Drittanbieteranwendungen erforderlich. Beispiel: In einer Abteilung werden die geographischen Daten in der Datenbank mit ArcGIS gepflegt, und in einer anderen Abteilung werden die Kundendaten in derselben Datenbank mit einer benutzerdefinierten Anwendung bearbeitet. Die benutzerdefinierte Anwendung muss bei den Transaktionen DBMS-Einschränkungen und Trigger anwenden und kann versionierte Tabellen möglicherweise nicht erkennen. Gleichzeitig muss die andere Abteilung die geographischen Daten in einer separaten und isolierten Version bearbeiten. Die Änderungen der Abteilung dürfen hierbei erst freigegeben werden, wenn diese vollständig und genehmigt sind.

Um diese Anforderungen zu erfüllen, ermöglicht es ArcGIS, versionierte Feature-Classes oder Tabellen zu bearbeiten und die Änderungen gleichzeitig mit anderen Anwendungen gemeinsam zu nutzen. Um diese Funktion für eine Feature-Class oder Tabelle zu aktivieren, registrieren Sie die Daten als versioniert mit der Option, die Änderungen in die Basistabelle zu verschieben. Diese Option ist nur im Dialogfeld "Registrierung" verfügbar.

Wenn Sie Daten bearbeiten, die auf diese Weise in der Basistabelle registriert wurden, verhalten sich die Versionen wie bei der zuvor beschriebenen Vorgehensweise, d. h., die Änderungen werden in den Delta-Tabellen gespeichert. Die Ausnahme dazu bildet die DEFAULT-Version. Bei jedem Speichern von Änderungen in der DEFAULT-Version durch direkte Bearbeitung oder durch Zusammenführen mit Änderungen aus einer anderen Version werden die Änderungen in den Basistabellen gespeichert. Die Änderungen verbleiben jedoch nicht in Delta-Tabellen, wie dies der Fall ist, wenn die Option zum Verschieben von Änderungen in die Basistabelle deaktiviert ist.

Auf diese Weise können alle Anwendungen mit derselben Datenbank arbeiten.

Verwalten von Daten mit ArcGIS- und Nicht-ArcGIS-Anwendungen

Potenzielle Anwendungsbereiche

Einschränkungen

Wenn Sie ein Dataset mit der Option zum Verschieben der Änderungen in die Basistabelle als versioniert registrieren, sind die Möglichkeiten für die Arbeit mit Versionen eingeschränkt.

Weitere Informationen zu Versionen und deren Funktionen finden Sie unter Versionierung und Versionierungsszenarien.

Verwandte Themen

9/11/2013