Geometrische Netzwerke in einer Geodatabase in PostgreSQL
Geometrische Netzwerke sind Sammlungen von Line-Feature-Classes (Kante) und Point-Feature-Classes (Knoten) in einem Feature-Dataset, die eine Konnektivitätsbeziehung haben. Geometrische Netzwerke werden zur Modellierung von Infrastruktur verwendet, z. B. elektrische Versorgungsleitungen und Abwassersysteme.
Die mit einem Netzwerk erstellten Tabellen hängen davon ab, ob im Netzwerk Kantenübergänge vorhanden sind.
Geometrische Netzwerke in ArcGIS for Desktop
Feature-Datasets, die geometrische Netzwerke enthalten, werden im Kataloginhaltsverzeichnis auf die gleiche Weise dargestellt, bis Sie das Dataset erweitern. Wenn Sie das Dataset erweitern, können Sie das geometrische Netzwerk anhand des folgenden Symbols erkennen:
Der Name eines geometrischen Netzwerks in einer Geodatabase in PostgreSQL enthält den Datenbanknamen, den Namen des Besitzers des geometrischen Netzwerks und den Namen des geometrischen Netzwerks selbst.
Beispielsweise wird ein geometrisches Netzwerk "water_net", das Benutzer "gdb" in einer Geodatabase mit dem Namen "sdedb" gehört, im Kataloginhaltsverzeichnis als "sdedb.gdb.water_net" aufgeführt.
Beim Aufbau eines geometrischen Netzwerks wird die Orphan-Junction-Feature-Class im Feature-Dataset erstellt. Der Name dieser Feature-Class ist der Name des Netzwerks, gefolgt von "_Junctions".
Alle Fehler, die beim Erstellen des geometrischen Netzwerks auftreten, werden der Fehlertabelle hinzugefügt, die Sie auch im Katalog einsehen können. Der Name dieser Tabelle lautet "<network_name>_builderr". Wenn beim Erstellen des geometrischen Netzwerks "water_net" Fehler aufgetreten sind, wird in der Geodatabase eine Tabelle mit dem Namen "sdedb.gdb.water_net_builderr" erzeugt.
Geometrische Netzwerke in einer PostgreSQL-Datenbank
Geometrische Netzwerke werden in der Tabelle gdb_items verfolgt. In der Tabelle gdb_itemtypes wird ein Wert gespeichert, der angibt, dass das Objekt ein geometrisches Netzwerk ist. In der Tabelle gdb_itemrelationships werden Informationen über die Beziehung zwischen dem Netzwerk und dem Feature-Dataset gespeichert, in dem dieses enthalten ist.
Neben diesen Tabellen werden Netzwerke aus einer Reihe von Tabellen mit unterschiedlicher Größe aufgebaut, die im Schema des Benutzers gespeichert werden, der das geometrische Netzwerk erstellt hat. Die Größe dieser Tabellen hängt von der Größe des Netzwerks ab, z. B. von der Anzahl der Knoten und der Anzahl der Kanten, die die Netzwerkgröße beeinflussen können.
Es gibt 9 feste Tabellen pro Netzwerk, die anhand der folgenden Namenskonvention zu identifizieren sind: N_<ID>_<Tabellendeskriptor>. Dabei steht "ID" für die logische ID des Netzwerks, die in der Netzwerkdefinition in der Tabelle gdb_items gespeichert ist, z. B. N_1_<Tabellendeskriptor>, N_2_<Tabellendeskriptor>.
Die tatsächliche Anzahl der Tabellen hängt davon ab, welche Elemente das Netzwerk enthält. Für ein Netzwerk mit Kantenübergängen und Gewichtungen können maximal 21 Tabellen erstellt werden.
Alle diese Tabellen werden versioniert, wenn das Netzwerk selbst versioniert wird.
Die folgenden Tabellen werden immer erstellt: n_<id>_desc, n_<id>_e<#>, n_<id>_estatus, n_<id>_etopo, n_<id>_flodir, n_<id>_jdesc, n_<id>_jstatus, n_<id>_jtopo und n_<id>_props.
Die Tabellen namens "N_<ID>_*" können im DBMS angezeigt werden, sollten jedoch nicht mit SQL-Anwendungen bzw. Anwendungen von Drittanbietern geändert werden, da hierdurch das Netzwerk beschädigt werden kann.
n_<id>_<>
In Tabellen in der Geodatabase, die mit "N_" beginnen, sind Informationen zu Netzwerken gespeichert.
n_<id>_desc
In der Tabelle n_<id>_desc werden die Elemente eines Netzwerks beschrieben. Dies ist eine normalisierte Tabelle, deren Zeilenanzahl der Anzahl von Knoten und der Anzahl von Kanten in einem geometrischen Netzwerk entspricht.
Feldtyp |
Beschreibung |
NULL? | |
---|---|---|---|
oid Feldname |
integer |
Die eindeutige Kennung eines Elements in einem geometrischen Netzwerk |
NOT NULL |
userclassid |
integer |
Die Kennung der Feature-Class, zu der das Element gehört |
NOT NULL |
userid |
integer |
Die ObjectID des Features |
NOT NULL |
usersubid |
integer |
Die Kennung eines Elements in einem Feature (gilt nur für komplexe Kanten-Features) |
NOT NULL |
elementtype |
smallint |
Ein Code, der den Typ des Netzwerkelements angibt (1 = Knoten oder 2 = Kante) |
NOT NULL |
eid |
integer |
Die eindeutige Elementkennung des Netzwerkelements (nur für den Typ des Netzwerkelements eindeutig) |
NOT NULL |
n_<id>_props
Die Tabelle n_<id>_props enthält eine Kurzbeschreibung von den Eigenschaften eines Netzwerks, z. B. Elementanzahl und maximale EID-Werte.
Feldname |
Feldtyp |
Beschreibung |
NULL? |
---|---|---|---|
propertyid |
integer |
Die eindeutige Kennung der Netzwerkeigenschaft |
NOT NULL |
propertyname |
varchar(32) |
Der Name der Eigenschaft |
NOT NULL |
propertyvalue |
integer |
Der Wert der Eigenschaft |
NOT NULL |
Alle verbleibenden Netzwerktabellen enthalten die gleichen Feldnamen und Typen. Die Tabellennamen und die verfolgten Elemente werden unterhalb der Tabellendefinition beschrieben.
Feldname |
Feldtyp |
Beschreibung |
NULL? |
---|---|---|---|
oid |
integer |
Die eindeutige ID der Seite "bytea" in der Tabelle |
NOT NULL |
pagenumber |
integer |
Die Nummer der Seite "bytea" in der Tabelle |
NOT NULL |
pageblob |
bytea |
Die Beschreibung für das Element, das in der Tabelle beschrieben wird, z. B. Kante und Kantenstatus |
- n_<id>_e<#>: Beschreibt Netzwerkkantengewichtungen; #= 2, 3, 4 oder 5
- n_<id>_edesc: Beschreibt die Kanten in einem Netzwerk
- n_<id>_estatus: Beschreibt den Status jeder Kante, einschließlich des Lösch- und Deaktivierungsstatus
- n_<id>_etopo: Beschreibt die Netzwerkkantentopologie oder Konnektivität
- n_<id>_flodir: Beschreibt die Netzwerkfließrichtung
- n_<id>_j<#>: Beschreibt Netzwerkknotengewichtungen; #= 0 oder 1
- n_<id>_jdesc: Beschreibt die Netzwerkknoten
- n_<id>_jstatus: Beschreibt den Status jedes Netzwerkknotens, einschließlich des Lösch- und Deaktivierungsstatus
- n_<id>_jtopo: Beschreibt die Konnektivität von Knotenelementen mit Kantenelementen
- n_<id>_jtopo2: Beschreibt die Konnektivität von Knotenelementen mit Kantenelementen, wenn mehrere Kanten mit einem einzelnen Knoten verbunden sind
- n_<id>_t<#>*: Beschreibt die Gewichtungswerte jedes Kantenübergangselements
- n_<id>_tdefn*: Definiert jedes Kantenübergangselement durch Auflistung der Kanten und Knoten, aus denen der Kantenübergang besteht
- n_<id>_tdefn2*: Überlauftabelle für die Definition des Kantenübergangselements, z. B. wenn mehrere Kanten einen Kantenübergang bilden
- n_<id>_tdesc*: Beschreibt die Kantenübergänge in einem Netzwerk
- n_<id>_tstatus*: Beschreibt den Status jedes Netzwerkkantenübergangs, einschließlich des Lösch- und Deaktivierungsstatus
View a diagram of a geometric network in PostgreSQL.
Die gestrichelten Linien geben implizite Beziehungen zwischen Spalten an.
Sie benötigen Adobe Acrobat Reader, um die Datei zu öffnen.
Eine Beschreibung der Berechnungsfehlertabelle finden Sie unter Schema der Netzwerkfehlertabelle.
Geometrische Netzwerke in einem XML-Workspace-Dokument
Für ein geometrisches Netzwerk wird das Datenelement in einem XML-Dokument als Typ "GeometricNetwork" aufgeführt. Im Folgenden ist ein Teil eines XML-Dokuments zu sehen, das aus einem Feature-Dataset mit einem geometrischen Netzwerk exportiert wurde:
<DataElement xsi:type="esri:DEGeometricNetwork">
<CatalogPath>/V=sde.DEFAULT/FD=m6db.perrita.Electric/GN=m6db.perrita.Electric_Net</CatalogPath>
<Name>m6db.perrita.Electric_Net</Name>
<DatasetType>esriDTGeometricNetwork</DatasetType>
<DSID>-1</DSID>
<Versioned>false</Versioned>
<CanVersion>true</CanVersion>
<Extent xsi:type="esri:EnvelopeN">
<XMin>0</XMin>
<YMin>0</YMin>
<XMax>6229821.98995209</XMax>
<YMax>2299265.90002099</YMax>
<SpatialReference xsi:type="esri:ProjectedCoordinateSystem">
<WKT>PROJCS["NAD_1983_StatePlane_California_VI_FIPS_0406_Feet", GEOGCS["GCS_North_American_1983", DATUM["D_North_American_1983", SPHEROID["GRS_1980",6378137.0,298.257222101]], PRIMEM["Greenwich",0.0], UNIT["Degree",0.0174532925199433]], PROJECTION["Lambert_Conformal_Conic"], PARAMETER["False_Easting",6561666.666666666], PARAMETER["False_Northing",1640416.666666667], PARAMETER["Central_Meridian",-116.25], PARAMETER["Standard_Parallel_1",32.78333333333333], PARAMETER["Standard_Parallel_2",33.88333333333333], PARAMETER["Latitude_Of_Origin",32.16666666666666], UNIT["Foot_US",0.3048006096012192]]</WKT>
<XOrigin>5937666.642992</XOrigin>
<YOrigin>2016067.94250924</YOrigin>
<XYScale>31249.9999708962</XYScale>
<ZOrigin>0</ZOrigin>
<ZScale>1</ZScale>
<MOrigin>0</MOrigin>
<MScale>1</MScale>
<XYTolerance>6.56166666666667E-04</XYTolerance>
<ZTolerance>0.00002</ZTolerance>
<MTolerance>0.00002</MTolerance>
<HighPrecision>true</HighPrecision>
</SpatialReference>
</Extent>
<SpatialReference xsi:type="esri:ProjectedCoordinateSystem">
<WKT>PROJCS["NAD_1983_StatePlane_California_VI_FIPS_0406_Feet", GEOGCS["GCS_North_American_1983", DATUM["D_North_American_1983", SPHEROID["GRS_1980",6378137.0,298.257222101]], PRIMEM["Greenwich",0.0], UNIT["Degree",0.0174532925199433]], PROJECTION["Lambert_Conformal_Conic"], PARAMETER["False_Easting",6561666.666666666], PARAMETER["False_Northing",1640416.666666667], PARAMETER["Central_Meridian",-116.25], PARAMETER["Standard_Parallel_1",32.78333333333333], PARAMETER["Standard_Parallel_2",33.88333333333333], PARAMETER["Latitude_Of_Origin",32.16666666666666], UNIT["Foot_US",0.3048006096012192]]</WKT>
<XOrigin>5937666.642992</XOrigin>
<YOrigin>2016067.94250924</YOrigin>
<XYScale>31249.9999708962</XYScale>
<ZOrigin>0</ZOrigin>
<ZScale>400000</ZScale>
<MOrigin>0</MOrigin>
<MScale>400000</MScale>
<XYTolerance>6.56166666666667E-04</XYTolerance>
<ZTolerance>0.00002</ZTolerance>
<MTolerance>0.00002</MTolerance>
<HighPrecision>true</HighPrecision>
</SpatialReference>
<NetworkType>esriNTUtilityNetwork</NetworkType>
<OrphanJunctionFeatureClassName>m6db.perrita.Electric_Net_Junctions</OrphanJunctionFeatureClassName>
<FeatureClassNames xsi:type="esri:Names">
<Name>m8db.perrita.Prime</Name>
<Name>m8db.perrita.Secondary</Name>
<Name>m8db.perrita.bridging</Name>
<Name>m8db.perrita.circuit_bkr</Name>
<Name>m8db.perrita.StreetLights</Name>
<Name>m8db.perrita.meters</Name>
<Name>m8db.perrita.switch</Name>
<Name>m8db.perrita.transformers</Name>
<Name>m8db.perrita.Tapwire</Name>
<Name>m8db.perrita.Electric_Net_Junctions</Name>
</FeatureClassNames>
<ConnectivityRules xsi:type="esri:ArrayOfConnectivityRule" />
<NetworkWeights xsi:type="esri:ArrayOfNetWeight">
<NetWeight xsi:type="esri:NetWeight">
<WeightID>0</WeightID>
<WeightName>switch</WeightName>
<WeightType>esriWTInteger</WeightType>
<BitGateSize>0</BitGateSize>
</NetWeight>
</NetworkWeights>
<WeightAssociations xsi:type="esri:ArrayOfNetWeightAssociation">
<NetWeightAssociation xsi:type="esri:NetWeightAssociation">
<WeightID>0</WeightID>
<TableName>m8db.perrita.switch</TableName>
<FieldName>Status</FieldName>
</NetWeightAssociation>
</WeightAssociations>
</DataElement>