Logo des digitalen Schulbuchs inf-schule.de. Schriftzug in Zustandsübergangsdiagramm eines endlichen Automaten.

Exkurs - Funktionen in der Ausgabe

SQL kann auch Funktionen anwenden, um die Werte von Ausgabespalten zu berechnen.

Leider ist die Sprache hier nicht standardisiert, so dass unterschiedliche Datenbanksysteme verschiedene Syntax verwenden können.

Die folgenden einfachen Beispiele beziehen sich auf das freie Datenbanksystem MySQL.

Beispiel 1: Verbinden von Textfeldern

SQL Fenster öffnen Häufig will man bei Personen den Vor- und Nachnamen zusammenfassen, z.B. "Lindemann, Erwin". In SQL erlaubt dies der Befehl CONCAT

Ergebnistabelle bei Nutzung des CONCAT-Befehls

SELECT CONCAT(Name, ', ', Vorname) AS Name
  FROM benutzer
 ORDER BY Name DESC

Beachte, dass hier der Aliasname der berechneten Spalte auch in der Sortierung verwendet wird.

Beispiel 2: Berechnen des Alters

SQL Fenster öffnen Den Geburtstag des Benutzers kann man verwenden, um dessen Alter zu berechnen.

SELECT Name, Vorname, 
       DATEDIFF(NOW(),GebDat) AS Tage,   
	   ROUND(DATEDIFF(NOW(),GebDat)/365) AS Jahre,
	   DAYNAME(GebDat) AS Wochentag
  FROM benutzer
 ORDER BY Tage DESC

Ergebnistabelle des SQL-Befehls mit berechneten Spalten Tage, Jahre und Wochentag

Zur Erklärung:

Beispiel 3: Teilen von Zeichenketten

SQL Fenster öffnen Es könnte interessant sein herauszufinden, welchen Datentyp die Bilddatei hat - z.B. für die Anzeige. Der folgende Befehl kann hier helfen:

SELECT Name, 
       INSTR(Name,'.') AS Position, 
       MID(Name, INSTR(Name,'.')) AS Bildtyp
  FROM bild

Ergebnistabelle des SQL-Befehls mit berechneten Spalten Position und Bildtyp

Der Befehl INSTR(...) sucht die Position des Punktes im Text, MID(...) gibt den Teilstring ab dieser Position zurück.

X

Fehler melden

X

Suche