Mit der Standard- oder Advanced-Lizenz verfügbar.
Als Geodatabase-Administrator müssen Sie gelegentlich überprüfen, wer mit der Geodatabase verbunden ist und welche Verbindungen Ressourcen sperren. Sie müssen möglicherweise sogar bestimmte Verbindungen entfernen. Ein Editor hat möglicherweise eine Bearbeitungssitzung geöffnet gelassen, wodurch die Daten in der Bearbeitungssitzung gesperrt und andere Editoren nicht darauf zugreifen können. Wenn die Anzahl der Verbindungen, die mit einer Geodatabase hergestellt werden können, beschränkt ist, müssen Sie einen Benutzer, der sich nicht abgemeldet hat, möglicherweise trennen, um eine Verbindung freizugeben. Sie können jedoch auch alle Benutzer abmelden, um ein Patch auf die Datenbank anzuwenden, die Datenbank wiederherzustellen oder die Geodatabase zu komprimieren.
Wenn die Benutzer nicht anwesend sind, um sich selbst abzumelden, können Sie als Geodatabase-Administrator über ArcGIS for Desktop oder mit einer ArcPy-Funktion eine Verbindung mit der Geodatabase herstellen und die Verbindungen der Benutzer trennen.
Um die Verbindung von Benutzern mit einer Geodatabase in Oracle zu trennen, müssen dem Geodatabase-Administrator entweder die Rolle DBA hinzugefügt oder die Berechtigungen ALTER SYSTEM und SELECT_CATALOG_ROLE gewährt werden.
Ermitteln Sie zunächst, wer mit der Geodatabase verbunden ist, und entfernen Sie Verbindungen nach Bedarf. Sie können eine Verbindung mit der Geodatabase in ArcGIS for Desktop mithilfe der ArcPy-Funktion DisconnectUser herstellen.
Identifizieren und entfernen Sie Verbindungen über ArcGIS for Desktop
Sie können als Geodatabase-Administrator in ArcGIS for Desktop eine Verbindung mit der Geodatabase herstellen, um Verbindungen im Dialogfeld Geodatabase-Verwaltung anzuzeigen und zu entfernen.
- Starten Sie ArcMap oder ArcCatalog.
- Stellen Sie eine Verbindung mit der Geodatabase als Geodatabase-Administrator her.
- Klicken Sie im Kataloginhaltsverzeichnis mit der rechten Maustaste auf die Datenbankverbindung, zeigen Sie auf Verwaltung, und klicken Sie auf Geodatabase verwalten.
- Klicken Sie auf die Registerkarte Verbindungen.
Eine Liste aller Benutzersitzungen, die gerade mit der Geodatabase verbunden sind, wird angezeigt. Ihre Sitzung wird in kursivem Text angezeigt.
- Wenden Sie sich an einzelne Benutzer, um sie zu bitten, ihre Sitzungen zu schließen. Falls Sie sie nicht erreichen können und sie dennoch von der Geodatabase trennen müssen, fahren Sie mit dem nächsten Schritt fort.
- Klicken Sie mit der rechten Maustaste auf die entsprechende Benutzersitzung, die Sie aus der Geodatabase entfernen möchten, und klicken Sie auf Trennen.
Die Benutzersitzung wird sofort aus der Geodatabase gelöscht.
Identifizieren und Entfernen von Verbindungen mit ArcPy
Sie können Python-Funktionen ausführen, um eine Geodatabase-Verbindung zu definieren, die Benutzer aufzulisten, die aktuell mit der Geodatabase verbunden sind, und um eine Verbindung aus der Geodatabase zu entfernen.
- Erstellen Sie eine Datenbankverbindungsdatei, indem Sie die Funktion CreateDatabaseConnection_management in einem Python-Fenster ausführen. Speichern Sie den Benutzernamen und das Kennwort mit der Datei.
In diesem Beispiel wird im temporären Ordner eine Verbindungsdatei (oragdb.sde) erstellt. Die Verbindung wird durch die Anmeldung als SDE-Benutzer mit der Datenbank "spora" hergestellt.
import arcpy arcpy.CreateDatabaseConnection_management ("c:\\temp", "oragdb.sde", "ORACLE", "spora", "DATABASE_AUTH", "sde", "mysdepwd", "SAVE_USERNAME")
- Führen Sie die Funktion ListUsers aus, um eine Liste der aktuellen Verbindungen mit der Geodatabase "spora" abzurufen.
Geben Sie die Verbindungsdatei an, die Sie im vorherigen Schritt erstellt haben.
##No need to import arcpy if you are running functions in the same Python window. import arcpy arcpy.ListUsers("c:\\temp\oragdb.sde")
Es wird eine Liste der Benutzerverbindungen zurückgegeben.
[user(ClientName=u'PC4', ConnectionTime=datetime.datetime(2014, 2, 18, 8, 30, 19), ID=18, IsDirecConnection=True, Name=u'publisher1')] [user(ClientName=u'PC25', ConnectionTime=datetime.datetime(2014, 2, 21, 14, 10, 43), ID=33, IsDirecConnection=True, Name=u'editor2')] [user(ClientName=u'PC11', ConnectionTime=datetime.datetime(2014, 2, 22, 9, 18, 26), ID=39, IsDirecConnection=True, Name=u'reader5')] [user(ClientName=u'PCA2', ConnectionTime=datetime.datetime(2014, 2, 22, 11, 21, 2), ID=41, IsDirecConnection=True, Name=u'sde')]
- Wenden Sie sich an einzelne Benutzer, um sie zu bitten, ihre Sitzungen zu schließen. Falls Sie sie nicht erreichen können und sie dennoch von der Geodatabase trennen müssen, fahren Sie mit dem nächsten Schritt fort.
- Ermitteln Sie anhand der mit der Funktion ListUsers abgerufenen Informationen, welche Verbindung entfernt werden muss, indem Sie die Funktion DisconnectUser verwenden.
Geben Sie die ID der zu entfernenden Verbindung an. Hier wird die Verbindung mit der ID 33 entfernt:
##No need to import arcpy if you are running functions in the same Python window. import arcpy arcpy.DisconnectUser("c:\\temp\oragdb.sde",33)
Die Benutzersitzung wird sofort aus der Geodatabase gelöscht.