Beim Erstellen einer Tabelle oder Hinzufügen einer Spalte zur Tabelle einer Datenbank definieren Sie einen bestimmten Datentyp für die Spalte. Durch Datentypen wird Folgendes festgelegt:
- Welche Werte in der Spalte gespeichert werden können
- Welche Operationen mit den Daten in dieser Spalte ausgeführt werden dürfen
- Wie die Daten aus dieser Spalte in der Datenbank gespeichert werden
ArcGIS verwendet bestimmte Datentypen. Wenn Sie über eine Datenbankverbindung oder über einen Abfrage-Layer auf eine Datenbanktabelle zugreifen, filtert ArcGIS alle nicht unterstützten Datentypen heraus. Da nicht unterstützte Datentypen in ArcGIS nicht angezeigt werden, können Sie sie in ArcGIS nicht bearbeiten. Wenn beispielsweise ArcGIS zum Kopieren und Einfügen von Tabellen, die nicht unterstützte Datentypen enthalten, von einer Datenbank in eine andere verwendet wird, fügt ArcGIS nur die Spalten ein, deren Datentyp unterstützt wird.
Die erste Spalte der folgenden Tabelle enthält die ArcGIS-Datentypen. In der zweiten Spalte sind die von ArcGIS erstellten SQL Server-Datentypen aufgeführt. In der dritten Spalte ist aufgelistet, welche weiteren SQL Server-Datentypen (sofern vorhanden) dem ArcGIS-Datentyp zugeordnet werden, wenn Sie eine Tabelle anzeigen, die außerhalb von ArcGIS erstellt wurde. Die letzte Spalte enthält ggf. zusätzliche Informationen.
ArcGIS-Datentypen | Erstellte SQL Server-Datentypen | Andere SQL Server-Datentypen, die angezeigt werden können | Hinweise |
---|---|---|---|
BLOB | VARBINARY(MAX) | BINARY, IMAGE, TIMESTAMP, VARBINARY(n) | |
DATE | DATETIME2(7) | DATETIME2(n), DATETIME, SMALLDATETIME | |
DOUBLE | NUMERIC(p,s) | DECIMAL, FLOAT, MONEY, SMALLMONEY | Die Genauigkeit und die Anzahl der Dezimalstellen, die in ArcGIS angegeben sind, können Auswirkungen auf den resultierenden Datentyp haben, der in der Datenbank erstellt wird. Weitere Informationen finden Sie unter ArcGIS-Felddatentypen. |
FLOAT | NUMERIC(p,s) | REAL | Die Genauigkeit und die Anzahl der Dezimalstellen, die in ArcGIS angegeben sind, können Auswirkungen auf den resultierenden Datentyp haben, der in der Datenbank erstellt wird. Weitere Informationen finden Sie unter ArcGIS-Felddatentypen. |
GEOMETRY |
| Welcher SQL Server-Datentyp in einer Enterprise-Geodatabase erstellt wird, hängt von dem Parameter GEOMETRY_STORAGE des Konfigurationsschlüsselworts ab, das beim Erstellen der Feature-Class verwendet wurde. SDEBINARY = INT; GEOMETRY = eine GEOMETRY-Spalte; GEOGRAPHY = eine GEOGRAPHY-Spalte. In einer Datenbank geben Sie an, ob "GEOMETRY" oder "GEOGRAPHY" beim Erstellen einer Feature-Class verwendet werden soll. In Desktop- und Workgroup-Geodatabases wird der Typ "GEOMETRY" immer verwendet. Die folgenden GEOMETRY-Subtypes werden von ArcGIS nicht unterstützt:
| |
GLOBAL ID | UNIQUEIDENTIFIER | Wird nur in Geodatabases unterstützt. | |
GUID | UNIQUEIDENTIFIER | ||
LONG INTEGER | INT | ||
RASTER | BLOB, INT, ST_RASTER | Raster-Datentypen werden nur in Geodatabases unterstützt. In Desktop- und Workgroup-Geodatabases werden Raster immer als BLOB-Datentyp erstellt. Welcher SQL Server-Datentyp in Enterprise-Geodatabases erstellt wird, hängt vom Konfigurationsschlüsselwort ab, das beim Erstellen des Raster-Datasets oder Mosaik-Datasets verwendet wurde. Wenn der Parameter "RASTER_STORAGE" des Schlüsselworts auf "RASTERBLOB" eingestellt ist, wird eine BLOB-Spalte erstellt; wenn er auf "BINARY" eingestellt ist, wird eine INT-Spalte erstellt und wenn er auf "ST_RASTER" eingestellt ist, wird eine ST_Raster-Spalte erstellt. Sie müssen den Typ "ST_Raster" in der Enterprise-Geodatabase getrennt konfigurieren, wenn Sie ihn verwenden möchten. Anweisungen finden Sie unter Installieren von ST_Raster in SQL Server. | |
OBJECT ID | INT(4) when created in an enterprise geodatabase INTEGER with IDENTITY property when created in a database | Die ArcGIS-Typ-ObjektID ist die registrierte Zeilen-ID-Spalte für die Tabelle (oder Feature-Class). Pro Tabelle gibt es nur eine. | |
SHORT INTEGER | SMALLINT | BIT, TINYINT | |
TEXT | VARCHAR, NVARCHAR, VARCHAR(MAX), NVARCHAR(MAX) | CHAR, NCHAR |
Textdatentypen
Wenn Sie ein VARCHAR- oder VARCHAR(MAX)-Feld in einer SQL Server-Datenbank erstellen, wird es dem ArcGIS-Datentyp "TEXT" zugeordnet, wenn es in ArcGIS angezeigt wird. Wenn Sie ein TEXT-Feld in einer SQL Server-Datenbank in ArcGIS erstellen, wird entweder "NVARCHAR" oder "NVARCHAR(MAX)" verwendet.
Wenn für den Konfigurationsparameter UNICODE_STRING in einer Enterprise-Geodatabase FALSE und für das Textfeld 7.999 Zeichen oder weniger festgelegt wurden, wird VARCHAR verwendet.
Wenn der Konfigurationsparameter UNICODE_STRING auf FALSE und das Textfeld auf 8.000 Zeichen oder mehr festgelegt sind, wird VARCHAR(MAX) verwendet.
Wenn der Konfigurationsparameter UNICODE_STRING auf TRUE und das Textfeld auf 3.999 Zeichen festgelegt sind, wird NVARCHAR verwendet.
Wenn der Konfigurationsparameter UNICODE_STRING auf TRUE und das Textfeld auf 4.000 Zeichen oder mehr festgelegt sind, wird NVARCHAR(MAX) verwendet.
Geometriedatentypen
Wie in der Tabelle angegeben, können von ArcGIS drei Geometriedatentypen in SQL Server erstellt und verwendet werden: "Compressed Binary" (komprimierte Binärdaten), "GEOMETRY" von SQL Server und "GEOGRAPHY" von SQL Server.
Compressed Binary
Der Speichertyp "Compressed Binary" von Esri verwendet einen binären Speichermechanismus zum Speichern von Feature-Geometrie. Der Geometriespeicher "Compressed Binary" kann nur in Geodatabases verwendet werden. Eine komprimierte binäre Feature-Class besteht aus drei Tabellen: die Business-Tabelle, die Feature-Tabelle und die räumliche Indextabelle.
Nach dem Überprüfen der Geometrie komprimiert die Client-Anwendung diese und sendet sie an die Geodatabase, in der sie im Compressed Binary-Format in einer Feature-Tabelle (oder F-Tabelle) gespeichert wird. Durch das Komprimieren der Geometrie auf dem Client wird der Task vom Datenbankserver entladen und die zum Senden der Geometrie benötigte Übertragungszeit reduziert. Zudem ermöglicht dies das effiziente Speichern und Abrufen räumlicher Daten, da der für die Daten benötigte Speicherplatz um bis zu 40 Prozent reduziert wird.
Die Business-Tabelle enthält Attribute und eine räumliche Spalte. Die räumliche Spalte dient als Schlüssel für die Feature-Tabelle und die räumliche Indextabelle.
Die Beziehung zwischen der Business-Tabelle und der Feature-Tabelle wird durch die gesamte räumliche Spalte und die FID-Spalte (Feature-ID) verwaltet. Dieser Schlüssel, der von ArcGIS verwaltet wird, ist eindeutig.
SQL Server-Geometrie
Der nachfolgende Abschnitt enthält eine Zusammenfassung des Datentyps "GEOMETRY" von Microsoft. Weitere Informationen zum Typ "GEOMETRY" und seiner Verwendung finden Sie in der Microsoft SQL Server-Dokumentation.
- Der Datentyp GEOMETRY von Microsoft unterstützt jedes X/Y-Koordinatensystem.
- Planare (Ebene, euklidisch) Berechnungen und lineare Interpolation zwischen Stützpunkten werden zum Rendern und für räumliche Vergleiche verwendet.
- Entspricht Version 1.1.9 der Simple Features-Spezifikation von Open Geospatial Consortium, Inc. (OGC) und ist mit dem ISO SQL/MM-Standard konform.
SQL Server-Geographie
Der nachfolgende Abschnitt enthält eine Zusammenfassung des Datentyps "GEOGRAPHY" von Microsoft. Weitere Informationen zum Datentyp "GEOGRAPHY" und zu seiner Verwendung finden Sie in der Microsoft SQL Server-Dokumentation.
- Der Typ "GEOGRAPHY" unterstützt viele standardmäßige geographische Koordinatensysteme wie GPS-Längengrad und -Breitengrad.
Microsoft erfordert die Verwendung von SRIDs und die Definition des geographischen Koordinatensystems im SQL Server-Data Dictionary.
- Ein Ellipsoid-Modell (runde Erde) und die Interpolation einer großen Ellipse aus Liniensegmenten zwischen Stützpunkten wird für Berechnungen und räumliche Vergleiche verwendet.
- Der Typ "GEOGRAPHY" verwendet eine globale (kugelförmige) Layer-Ausdehnung.
Koordinaten der Daten können die globale Ausdehnung nicht überschreiten.
Raster-Datentypen
Der in Geodatabases in SQL Server standardmäßig verwendete Raster-Typ ist ein BLOB-Typ (rasterblob). Wenn Sie mit SQL auf in Ihrer Geodatabase gespeicherte Raster zugreifen möchten, können Sie die Verwendung des Typs "ST_Raster" in der Enterprise-Geodatabase in SQL Server konfigurieren.
Ausführliche Informationen zur Definition des Objekttyps "ST_Raster" finden Sie unter Der ST_Raster-Datentyp.