Verwenden von SQL für Berichterstellung und Analyse von File-Geodatabases
File-Geodatabases ermöglichen verbesserte Analyse- und Berichtserstellungsfunktionen durch die Verwendung von Ausdrücken und Aliasnamen mithilfe der SubFields (Feldlisten)-Methode in einer Abfragedefinition. Außerdem werden ORDER BY und GROUP BY über die PostFixClause unterstützt. Bei GROUP BY können die Ausdrücke Zusammenfassungsfunktionen wie MIN, MAX und SUM enthalten.
ALIAS
Benennt eine Spalte um, sodass eine verständlichere Ausgabe entsteht.
SQL
SELECT NAME, POP1997 - POP1990 as PopChange
FROM counties ORDER BY NAME
ArcObjects
pQueryDef.SubFields = "NAME, POP1997 - POP1990 as PopChange"
pQueryDef.Tables = "counties"
pQueryDef.PostfixClause = "ORDER BY NAME"
CASE
Wertet eine Bedingungsliste aus und gibt einen von mehreren Ergebnisausdrücken zurück.
SQL
SELECT name,salary,
CASE
WHEN salary <= 2000 THEN 'low'
WHEN salary > 2000 AND salary <= 3000 THEN 'average'
WHEN salary > 3000 THEN 'high'
END AS salary_level
FROM employees
ORDER BY salary ASC
ArcObjects
pQueryDef.SubFields = "name,salary,
CASE
WHEN salary <= 2000 THEN 'low'
WHEN salary > 2000 AND salary <= 3000 THEN 'average'
WHEN salary > 3000 THEN 'high'
END AS salary_level"
pQueryDef.Tables = " employees"
pQueryDef.PostfixClause = " ORDER BY salary ASC "
COALESCE
Gibt den ersten Nicht-Null-Feldwert der Argumente zurück.
SQL
SELECT Name, COALESCE(Business_Phone, Cell_Phone, Home_Phone)
Contact_Phone
FROM Contact_Info
ArcObjects
queryDef.SubFields = "Name, COALESCE(Business_Phone, Cell_Phone,
Home_Phone) Contact_Phone"
queryDef.Tables = "Contact_Info"
Contact_Info:
Name |
Business_Phone |
Cell_Phone |
Home_Phone |
Jeff |
531-2531 |
622-7813 |
565-9901 |
Laura |
NULL |
772-5588 |
312-4088 |
Peter |
NULL |
NULL |
594-7477 |
Ergebnis:
Name |
Contact_Phone |
Jeff |
531-2531 |
Laura |
772-5588 |
Peter |
594-7477 |
AUSDRÜCKE
SQL
SELECT SIN(sunangle)
FROM sightings
ArcObjects
queryDef.SubFields = "SIN(sunangle)"
queryDef.Tables = "sightings"
SET-FUNKTIONEN
Operator | Beschreibung |
AVG |
Berechnet den Durchschnitt aller Werte in der Gruppe. NULL-Werte werden ignoriert. |
COUNT(*), COUNT(Ausdruck) |
COUNT(*) gibt die Anzahl der Datensätze in einer Tabelle zurück. NULL-Werte werden berücksichtigt. COUNT(Ausdruck) gibt die Anzahl der Werte im angegebenen Ausdruck zurück. NULL-Werte werden ignoriert. |
MAX |
Sucht die Maximalwerte in der Gruppe. NULL-Werte werden ignoriert. |
MIN |
Sucht die Minimalwerte in der Gruppe. NULL-Werte werden ignoriert. |
STDDEV, STDDEV_SAMP |
Gibt die Stichprobenstandardabweichung des Ausdrucks zurück. |
STDDEV_POP |
Gibt die Populationsstandardabweichung des Ausdrucks zurück. |
SUM |
Sucht die Werte in der Gruppe. NULL-Werte werden ignoriert. |
VAR, VAR_SAMP |
Gibt die Stichprobenvarianz des Ausdrucks zurück. |
VAR_POP |
Gibt die Populationsvarianz des Ausdrucks zurück. |
ARITHMETISCHE OPERATOREN
Arithmetische Operatoren werden zum Addieren, Subtrahieren, Multiplizieren und Dividieren von numerischen Werten verwendet.
Operator | Beschreibung |
* |
Arithmetischer Operator für die Multiplikation |
/ |
Arithmetischer Operator für die Division |
+ |
Arithmetischer Operator für die Addition |
- |
Arithmetischer Operator für die Subtraktion |
FUNKTIONEN
Im Folgenden finden Sie eine vollständige Liste der Funktionen, die von File-Geodatabases unterstützt werden.
Datumsfunktionen
Funktion | Beschreibung |
CURRENT_DATE |
Das aktuelle Datum wird zurückgegeben. |
EXTRACT (extract_field FROM extract_source) |
Hiermit wird der extract_field-Teil von extract_source zurückgegeben. Beim Argument extract_source handelt es sich um einen Datums-/Uhrzeitausdruck. Beim Argument extract_field kann es sich um eines der folgenden Schlüsselwörter handeln: YEAR, MONTH, DAY, HOUR, MINUTE oder SECOND. |
CURRENT TIME |
Die aktuelle Zeit wird zurückgegeben. |
CURRENT_TIMESTAMP |
Gibt das aktuelle Datum und die aktuelle Zeit zurück. |
Zeichenfolgefunktionen
Bei den Argumenten, die als string_exp aufgeführt sind, kann es sich um den Namen einer Spalte, ein Zeichenfolgenliteral oder das Ergebnis einer anderen Skalarfunktion handeln, in der der zugrunde liegende Datentyp als Zeichentyp dargestellt werden kann.
Bei Argumenten, die als character_exp aufgeführt sind, handelt es sich um Zeichenfolgen mit variabler Länge.
Bei Argumenten, die als start oder length aufgeführt sind, kann es sich um ein numerisches Literal oder das Ergebnis einer anderen Skalarfunktion handeln, wobei der zugrunde liegende Datentyp einen numerischen Typ darstellen kann.
Diese Zeichenfolge-Funktionen basieren auf 1, d. h. beim ersten Zeichen der Zeichenfolge handelt es sich um das Zeichen 1.
Funktion | Beschreibung |
CHAR_LENGTH (string_exp) |
Gibt die Länge des String-Ausdrucks in Zeichen zurück. |
CONCAT (string_exp1, string_exp2) |
Gibt eine Zeichenfolge zurück, die sich aus der Verknüpfung von string_exp2 mit string_exp1 ergibt. |
LOWER (string_exp) |
Gibt eine Zeichenfolge zurück, die mit string_exp identisch ist und in der alle Großbuchstaben in Kleinbuchstaben konvertiert wurden. |
POSITION (character_exp IN character_exp) |
Gibt die Position des ersten Zeichenausdrucks im zweiten Zeichenausdruck zurück. Das Ergebnis ist eine genaue Zahl mit einer implementationsdefinierten Genauigkeit und dem Maßstab 0. |
SUBSTRING (string_exp FROM start FOR length) |
Gibt eine aus string_exp abgeleitete Zeichenfolge zurück. Diese Zeichenfolge beginnt an der durch start festgelegten Zeichenposition und weist eine Länge von length Zeichen auf. |
TRIM(BOTH | LEADING | TRAILINGtrim_characterFROM string_exp) |
Gibt string_exp zurück, wobei trim_character von den führenden, nachstehenden oder beiden Enden der Zeichenfolge entfernt wurde. |
UPPER (string_exp) |
Gibt eine Zeichenfolge zurück, die mit string_exp identisch ist und in der alle Kleinbuchstaben in Großbuchstaben konvertiert wurden. |
Numerische Funktionen
Bei allen Zahlenfunktionen wird ein numerischer Wert zurückgegeben.
Bei den Argumenten, die als numeric_exp, float_exp, oder integer_exp aufgeführt sind, kann es sich um den Namen einer Spalte, das Ergebnis einer anderen Skalarfunktion oder ein numerisches Literal handeln, wobei der zugrunde liegende Datentyp als numerischer Typ dargestellt werden kann.
Funktion | Beschreibung |
ABS (numeric_exp) |
Gibt den absoluten Wert von numeric_exp zurück. |
ACOS (float_exp) |
Gibt den Arkuskosinus von float_exp als Winkel, ausgedrückt in Radianten, zurück. |
ASIN (float_exp) |
Gibt den Arkussinus von float_exp als Winkel, ausgedrückt in Radianten, zurück. |
ATAN (float_exp) |
Gibt den Arkustangens von float_exp als Winkel, ausgedrückt in Radianten, zurück. |
CEILING (numeric_exp) |
Gibt den kleinsten Ganzzahlwert, der größer als oder gleich numeric_exp ist, zurück. |
COS (float_exp) |
Gibt den Kosinus von float_exp zurück, wobei float_exp ein in Radianten ausgedrückter Winkel ist. |
FLOOR (numeric_exp) |
Gibt den größten Ganzzahlwert, der kleiner als oder gleich numeric_exp ist, zurück. |
LOG (float_exp) |
Gibt den natürlichen Logarithmus von float_exp zurück. |
LOG10 (float_exp) |
Gibt den Logarithmus zur Basis 10 von float_exp zurück. |
MOD (integer_exp1, integer_exp2) |
Gibt den Rest von integer_exp1 dividiert durch integer_exp2 zurück. |
POWER (numeric_exp, integer_exp) |
Gibt den Wert von numeric_exp potenziert mit integer_exp zurück. |
ROUND (numeric_exp, integer_exp) |
Gibt numeric_exp auf integer_exp Stellen rechts neben dem Dezimaltrennzeichen gerundet zurück. Wenn integer_exp negativ ist, wird numeric_exp auf |integer_exp| Stellen links neben dem Dezimaltrennzeichen gerundet. |
SIGN (numeric_exp) |
Gibt einen Indikator des Vorzeichens von numeric_exp zurück. Wenn numeric_exp kleiner als 0 ist, wird "-1" zurückgegeben. Wenn numeric_exp gleich 0 ist, wird 0 zurückgegeben. Wenn numeric_exp größer als 0 ist, wird "1" zurückgegeben. |
SIN (float_exp) |
Gibt den Sinus von float_exp zurück, wobei float_exp ein in Radianten ausgedrückter Winkel ist. |
TAN (float_exp) |
Gibt den Tangens von float_exp zurück, wobei float_exp ein in Radianten ausgedrückter Winkel ist. |
TRUNCATE (numeric_exp, integer_exp) |
Gibt numeric_exp auf integer_exp Stellen rechts neben dem Dezimaltrennzeichen verkürzt zurück. Wenn integer_exp negativ ist, wird numeric_exp auf |integer_exp| Stellen links neben dem Dezimaltrennzeichen verkürzt. |
GROUP BY
Wird zum Sammeln von Daten aus mehreren Datensätzen und Gruppieren der Ergebnisse nach einer oder mehreren Spalten verwendet.
SQL
SELECT STATE_NAME, SUM(POP1990) as TotalPopulation
FROM counties
GROUP BY STATE_NAME ORDER BY STATE_NAME
ArcObjects
pQueryDef.SubFields = "STATE_NAME, SUM(POP1990) as
TotalPopulation"
pQueryDef.Tables = "counties"
pQueryDef.PostfixClause = "GROUP BY STATE_NAME ORDER BY
STATE_NAME"
HAVING
Eine WHERE-Klausel für GROUP BY.
SQL
SELECT department, MAX(salary) as Highest_salary
FROM employees
GROUP BY department HAVING MAX(salary) < 50000
ArcObjects
queryDef.SubFields = "department, MAX(salary) as Highest_salary"
queryDef.Tables = "employees"
pQueryDef.PostfixClause = "GROUP BY department HAVING MAX(salary)
< 50000"
JOINS
Kombiniert die Datensätze aus zwei oder mehr Tabellen.
Cross Join
SQL
SELECT Table1.name, Table1.Address, Table2.name, Table2.Salary
FROM Table1 CROSS JOIN Table2
ArcObjects
queryDef.SubFields = "Table1.name, Table1.Address, Table2.name,
Table2.Salary"
queryDef.Tables = "Table1 CROSS JOIN Table2"
Inner Join
SQL
SELECT Table1.C1, Table1.C2, Table2.C3, Table2.C4 FROM Table1
INNER JOIN Table2 ON Table1.C1 = Table2.C3
ArcObjects
queryDef.SubFields = "Table1.C1, Table1.C2, Table2.C3,
Table2.C4"
queryDef.Tables = "Table1 INNER JOIN Table2 ON Table1.C1 =
Table2.C3"
Left Outer Join
SQL
SELECT Table1.C1, Table1.C2, Table2.C3, Table2.C4 FROM Table1
LEFT OUTER JOIN Table2 ON Table1.C1 = Table2.C3
ArcObjects
queryDef.SubFields = "Table1.C1, Table1.C2, Table2.C3,
Table2.C4"
queryDef.Tables = "Table1 LEFT OUTER JOIN Table2 ON Table1.C1 =
Table2.C3"
Right Outer Join
SQL
SELECT * FROM Table1 RIGHT OUTER JOIN Table2 ON Table1.C1 =
Table2.C3
ArcObjects
queryDef.SubFields = "*"
queryDef.Tables = "Table1 RIGHT OUTER JOIN Table2 ON Table1.C1 =
Table2.C3"
NULLIF
NULLIF gibt NULL zurück, wenn die beiden angegebenen Parameter gleich sind, andernfalls wird der Wert des ersten Parameters zurückgegeben.
SQL
SELECT Location, NULLIF(Sales, Forecast) as Results FROM
StoreSales
ArcObjects
queryDef.SubFields = " Location, NULLIF(Sales, Forecast) as
Results"
queryDef.Tables = "StoreSales"
StoreSales:
Location (Ort) | Sales (Umsätze) | Forecast (Prognose) |
Redlands |
39000 |
55000 |
Palm Springs |
60000 |
61000 |
Riverside |
40000 |
40000 |
Ergebnis:
Ort | Ergebnisse |
Redlands |
39000 |
Palm Springs |
60000 |
Riverside |
NULL |
ORDER BY
Gibt die Sortierreihenfolge an. Dabei sind eine aufsteigende (ASC) oder absteigende (DESC) Reihenfolge und verschiedene Sortieroptionen möglich. Zu den Sortiertypen zählen BINARY(BIN), CASESENSITIVE(CASE) und NOCASESENSITIVE(NOCASE). Bei der BINARY-Sortierung werden sowohl die Groß- und Kleinschreibung als auch Zeichen mit Akzenten berücksichtigt. Bei CASESENSITIVE wird zwischen Groß- und Kleinschreibung unterschieden. Bei NOCASESENSITIVE wird nicht zwischen Groß- und Kleinschreibung unterschieden.
SQL
SELECT STATE_NAME, POP1990
FROM counties ORDER BY STATE_NAME
ArcObjects
pQueryDef.SubFields = "STATE_NAME, POP1990"
pQueryDef.Tables = "counties"
pQueryDef.PostfixClause = "ORDER BY STATE_NAME"
SQL
SELECT STATE_NAME, POP1990
FROM counties ORDER BY STATE_NAME COLLATE BINARY ASC
ArcObjects
pQueryDef.SubFields = "STATE_NAME, POP1990"
pQueryDef.Tables = "counties"
pQueryDef.PostfixClause = "ORDER BY STATE_NAME COLLATE BINARY
ASC"