Embedded SQL

Embedded SQL

Embedded SQL (eingebettetes SQL, abgekürzt: ESQL) ist eine Spracherweiterung von SQL, mit der es möglich ist, SQL-Anweisungen innerhalb einer strukturierten oder objektorientierten Programmiersprache (der Hostsprache, typischerweise C, C++, COBOL, Ada, Pascal o. ä.) auszuführen. Es findet vornehmlich beim Serverumzug Anwendung.
Es unterscheidet sich von Inline-SQL, da letzteres mögliche Fehler direkt bei Kompilierung vor dem Laufen erkennt.

Technische Details

Blöcke mit SQL-Anweisungen und -Deklarationen werden dabei in bestimmte Embedded-SQL-Schlüsselwörter eingeschlossen, in den Code der Hostsprache eingefügt. Der SQL-Anteil am Quellcode wird entweder von dem Compiler selbst mit übersetzt (so machen es einige COBOL-Compiler) oder ein Precompiler wandelt die SQL-Anweisungen zuvor in normalen Code der Hostsprache um, der dann mit deren Compiler normal übersetzt werden kann. Der umgewandelte Code enthält Aufrufe der Schnittstelle zur Datenbank. Diese Schnittstelle muss als Bibliothek in das fertige Programm gelinkt werden. Die Bibliothek ist abhängig von der verwendeten Datenbank und wird gewöhnlich vom jeweiligen Datenbankhersteller geliefert, soweit dieser Embedded SQL überhaupt unterstützt.

Embedded SQL ist im SQL92-Standard definiert. Programme mit ESQL sollten daher, so lange keine proprietären Eigenschaften des jeweiligen SQL-Dialektes verwendet werden, kompatibel mit Datenbanken verschiedener Hersteller sein, allerdings nur auf Ebene des Quellcodes. Das heißt, dass bei Wechsel des Datenbankfabrikats, manchmal sogar beim Versionsupdate der gleichen Datenbank, der Quellcode durch den ESQL-Precompiler und Compiler neu übersetzt und gegen die aktuelle Bibliothek gelinkt werden muss. Dies unterscheidet Embedded SQL von Konzepten mit ähnlichem Einsatzzweck wie ODBC, wo beim Wechsel der Datenbank (theoretisch) nur ein Treiber ausgewechselt wird und das compilierte Programm weiter verwendet werden kann. Es gibt allerdings mindestens einen COBOL-Compiler, der ESQL-Anweisungen in Aufrufe von ODBC umwandelt.

Der große Vorteil dieses Ansatzes der Datenbankanbindung liegt darin, dass zur Compilezeit die SQL-Syntax und die Typverträglichkeit der Schnittstellenvariablen geprüft werden kann. Auf diesen großen Vorteil verzichtet man gänzlich, wenn man eine rein laufzeitgebundene Architektur (ODBC, ADO, ADO.NET, ...) verwendet.

Programmierung

Die Kommunikation zwischen SQL und dem Anwendungsprogramm erfolgt per Hostvariablen. Werden diese Hostvariablen in einem SQL-Ausdruck benutzt, so wird ihnen ein Doppelpunkt voran gestellt.

Beispiel:

EXEC SQL
SELECT vorname, nachname
INTO :vorname, :nachname
FROM mitarbeitertabelle
WHERE pnr = :pnr
;

Vor der Ausführung des SQL-Befehls muss in der umgebenden Programmiersprache die Variable 'pnr' mit einem Wert belegt werden. Nach Ausführung des SQL-Befehls sind die Variablen 'vorname' und 'nachname' mit Werten belegt - sofern überhaupt ein Satz gefunden wurde.

In einer Datenbank-Tabelle können Spalten mit Null-Werten definiert werden. Bei den meisten Programmiersprachen (mit Ausnahme von PL/SQL) können Variablen nicht mit Null-Werten belegt werden, sondern eine Variable ist immer mit irgendeinem Wert belegt.

Wenn auf Tabellenspalten zugegriffen werden soll, die auch Null-Werte enthalten, dann müssen Indikatorvariablen verwendet werden. Sie müssen vom Typ int angelegt werden. Diese Variable wird auf einen Wert kleiner 0 gesetzt, falls die Spalte in der Datenbank Null enthält.

Beispiel:

EXEC SQL
SELECT vorname, nachname
INTO :vorname :i_vorname, :nachname :i_nachname
FROM mitarbeitertabelle
WHERE pnr = :pnr
;

Die Variablen 'vorname' und 'nachname' werden hier - wie auch im Beispiel oben - zur Aufnahme der gelesenen Werte verwendet. Zusätzlich geben die Indikatorvariablen 'i_vorname' und 'i_nachname' an, ob der Vorname und der Nachname überhaupt vorhanden war. Wenn z.B. nur der Nachname gespeichert war und der Vorname unbekannt (Null) war, dann wurde 'i_nachname' mit 0 und 'i_vorname' mit -1 belegt.


Wikimedia Foundation.

Игры ⚽ Нужно сделать НИР?

Schlagen Sie auch in anderen Wörterbüchern nach:

  • Embedded SQL — is a method of combining the computing power of a programming language and the database manipulation capabilities of SQL. Embedded SQL statements are SQL statements written inline with the program source code of the host language. The embedded… …   Wikipedia

  • Embedded SQL — Embedded SQL  расширение какого либо базового языка программирования, позволяющее встраивать (англ. embed) команды языка структурированных запросов SQL непосредственно в текст программы. Прежде чем программа, использующая embedded SQL,… …   Википедия

  • Embedded SQL —   [Abk. für Embedded Structured Query Language, dt. »eingebettete strukturierte Abfragesprache«], eine Spracherweiterung zu SQL, die es ermöglicht, SQL Programme in prozedurale Programmiersprachen der dritten und vierten Generation, z. B. Pascal …   Universal-Lexikon

  • SQL-92 — SQL (das Kürzel für Structured Query Language; offizielle Aussprache [ɛskjuːˈɛl], häufig auch [ˈsiːkwəl] →SEQUEL), ist eine Datenbanksprache zur Definition, Abfrage und Manipulation von Daten in relationalen Datenbanken. SQL ist von ANSI und ISO… …   Deutsch Wikipedia

  • SQL-99 — SQL (das Kürzel für Structured Query Language; offizielle Aussprache [ɛskjuːˈɛl], häufig auch [ˈsiːkwəl] →SEQUEL), ist eine Datenbanksprache zur Definition, Abfrage und Manipulation von Daten in relationalen Datenbanken. SQL ist von ANSI und ISO… …   Deutsch Wikipedia

  • SQL — ist eine Datenbanksprache zur Definition, Abfrage und Manipulation von Daten in relationalen Datenbanken. SQL ist von ANSI und ISO standardisiert und wird von fast allen gängigen Datenbanksystemen unterstützt. Die Bezeichnung SQL (offizielle… …   Deutsch Wikipedia

  • SQL — Structured Query Language SQL Apparu en 1974 Auteur …   Wikipédia en Français

  • SQL Server Compact — Filename extension .sdf Developed by Microsoft Type of format Relational database Microsoft SQL Server Compact (SQL CE) is a compact relational database produced by Microsoft for applications that run on mobile devices and desktops. Prior to the… …   Wikipedia

  • SQL Anywhere — is an RDBMS product from Sybase iAnywhere. iAnywhere is a subsidiary of Sybase. Features * Database files are operating system independent. This means that they can be copied between supported platforms. * Can be run on Windows, Windows CE,… …   Wikipedia

  • SQL Server Compact — Saltar a navegación, búsqueda Microsoft SQL Server Compact (SQL Server CE) es un motor de base de datos relacional, de libre descarga y distribución, tanto para dispositivos móviles como para aplicaciones escritorio. Especialmente orientada a… …   Wikipedia Español

Share the article and excerpts

Direct link
Do a right-click on the link above
and select “Copy Link”