Presentation is loading. Please wait.

Presentation is loading. Please wait.

UJeffrey D. Ullman uAnfang von: CS145 - Herbst 2004 - Stanford University uOnline unter: www.odbms.org www.odbms.org Folien mit weißem Hintergrund wurden.

Similar presentations


Presentation on theme: "UJeffrey D. Ullman uAnfang von: CS145 - Herbst 2004 - Stanford University uOnline unter: www.odbms.org www.odbms.org Folien mit weißem Hintergrund wurden."— Presentation transcript:

1 uJeffrey D. Ullman uAnfang von: CS145 - Herbst 2004 - Stanford University uOnline unter: www.odbms.org www.odbms.org Folien mit weißem Hintergrund wurden hinzugefügt!

2 2 Real SQL Programming Embedded SQL Call-Level Interface Java Database Connectivity

3 3 SQL in Real Programs uWe have seen only how SQL is used at the generic query interface --- an environment where we sit at a terminal and ask queries of a database. uReality is almost always different. wPrograms in a conventional language like C are written to access a database by “calls” to SQL statements.

4 4 Host Languages uAny conventional language can be a host language, that is, a language in which SQL calls are embedded. uThe use of a host/SQL combination allows us to do anything computable, yet still get the very-high-level SQL interface to the database.

5 5 Kommt man auch ohne host language aus? Abhängig vom SQL Standard wTheorie sagt: Mit “if” (Bedingung) und “while” (Schleife) kriege ich alles hin! wSQL92 bietet dies nicht  z.B. Berechnung der Fakultät nicht möglich (n!). wIBM DB2 erlaubt mitlerweile rekursives SQL (nach SQL3) w… wie auch immer, host language bietet viele Vorteile!

6 6 Connecting SQL to the Host Language 1.Embedded SQL is a standard for combining SQL with seven languages. 2.CLI (Call-Level Interface ) is a different approach to connecting C to an SQL database. 3.JDBC (Java Database Connectivity ) is a way to connect Java with an SQL database.

7 7 Bemerkungen u CLI beschreibt wie aufgerufen wird, es ist nicht auf C beschränkt! u JDBC basiert ebenfalls auf CLI  ist eine Umsetzung des CLI in Java Mehr hierzu in der nächsten Vorlesung!

8 8 Embedded SQL uKey idea: Use a preprocessor to turn SQL statements into procedure calls that fit with the host-language code surrounding. uAll embedded SQL statements begin with EXEC SQL, so the preprocessor can find them easily.

9 9 Ausführbares Programm Linker Compiler Precompiler Quelltext mit SQL-Befehlen Quelltext in reiner host language Objektdatei SQL LIB STD LIB

10 10 Shared Variables uTo connect SQL and the host-language program, the two parts must share some variables. uDeclarations of shared variables are bracketed by: EXEC SQL BEGIN DECLARE SECTION; EXEC SQL END DECLARE SECTION; Always needed

11 11 Use of Shared Variables uIn SQL, the shared variables must be preceded by a colon. wThey may be used as constants provided by the host-language program. wThey may get values from SQL statements and pass those values to the host- language program. uIn the host language, shared variables behave like any other variable.

12 12 Example: Looking Up Prices uWe’ll use C with embedded SQL to sketch the important parts of a function that obtains a beer and a bar, and looks up the price of that beer at that bar. uAssumes database has our usual Sells(bar, beer, price) relation.

13 13 Example: C Plus SQL EXEC SQL BEGIN DECLARE SECTION; char theBar[21], theBeer[21]; float thePrice; EXEC SQL END DECLARE SECTION; /* obtain values for theBar and theBeer */ EXEC SQL SELECT price INTO :thePrice FROM Sells WHERE bar = :theBar AND beer = :theBeer; /* do something with thePrice */ Note 21-char arrays needed for 20 chars + endmarker SELECT-INTO just like PSM

14 14 Embedded Queries uEmbedded SQL has the same limitations as PSM regarding queries: wYou may use SELECT-INTO for a query guaranteed to produce a single tuple. wOtherwise, you have to use a cursor. Small syntactic differences between PSM and Embedded SQL cursors, but the key ideas are identical.

15 15 Cursor Statements uDeclare a cursor c with: EXEC SQL DECLARE c CURSOR FOR ; uOpen and close cursor c with: EXEC SQL OPEN CURSOR c; EXEC SQL CLOSE CURSOR c; uFetch from c by: EXEC SQL FETCH c INTO ; wMacro NOT FOUND is true if and only if the FETCH fails to find a tuple.

16 16 Example --- (1) uLet’s write C + SQL to print Joe’s menu --- the list of beer-price pairs that we find in Sells(bar, beer, price) with bar = Joe’s Bar. uA cursor will visit each Sells tuple that has bar = Joe’s Bar.

17 17 Example --- (2: Declarations) EXEC SQL BEGIN DECLARE SECTION; char theBeer[21]; float thePrice; EXEC SQL END DECLARE SECTION; EXEC SQL DECLARE c CURSOR FOR SELECT beer, price FROM Sells WHERE bar = ’Joe’’s Bar’; The cursor declaration goes outside the declare-section

18 18 Example --- (3: Executable) EXEC SQL OPEN CURSOR c; while(1) { EXEC SQL FETCH c INTO :theBeer, :thePrice; if (NOT FOUND) break; /* format and print theBeer and thePrice */ } EXEC SQL CLOSE CURSOR c; The C style of breaking loops


Download ppt "UJeffrey D. Ullman uAnfang von: CS145 - Herbst 2004 - Stanford University uOnline unter: www.odbms.org www.odbms.org Folien mit weißem Hintergrund wurden."

Similar presentations


Ads by Google