1 SQL in the Real World Chapter 10. 2 Interactive vs. Non-Interactive SQL Interactive SQL: SQL statements input from terminal; DBMS outputs to screen.

Slides:



Advertisements
Similar presentations
1 Constraints, Triggers and Active Databases Chapter 9.
Advertisements

Copyright  Oracle Corporation, All rights reserved. 2 Java and Databases: An Overview.
CSC343 – Introduction to databases – A. Vaisman1 Database Application Development.
1 Combining SQL and Conventional Programming Languages Source: slides by Jeffrey Ullman.
Embedded SQL John Ortiz. Lecture 15Embedded SQL2 Why Isn’t Interactive SQL Enough?  How to do this using interactive SQL?  Print a well-formatted transcript.
Copyright © 2011 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Chapter 13 Introduction to SQL Programming Techniques.
Distributed Application Development B. Ramamurthy.
Murali Mani SQL with other Programming Languages.
End of SQL: Triggers, Impedance Mismatch and Transactions February 6 th, 2004.
SPRING 2004CENG 3521 SQL: Constraints, Triggers, Embedded SQL Chapters: 5, 6.
1 C. Shahabi Application Programming for Relational Databases Cyrus Shahabi Computer Science Department University of Southern California
EmbeddedSQL: 1 Impedance Mismatch Problem Problem : How to connect SQL statements with conventional programming languages Different models of language.
Winter 2002Arthur Keller – CS 18011–1 Schedule Today: Feb. 7 (TH) u PL/SQL, Embedded SQL, CLI, JDBC. u Read Sections 8.1, Feb. 12 (T) Advising.
COMP 5138 Relational Database Management Systems Semester 2, 2007 Lecture 8A Transaction Concept.
SEMESTER 1, 2013/2014 DB2 APPLICATION DEVELOPMENT OVERVIEW.
Advance Computer Programming Java Database Connectivity (JDBC) – In order to connect a Java application to a database, you need to use a JDBC driver. –
1 Section 6 Embedded SQL. 6-2 CA306 Embedded SQL Section Content 6.1Embedded SQL 6.2Java Database Connectivity 6.3Web Databases.
Getting connected.  Java application calls the JDBC library.  JDBC loads a driver which talks to the database.  We can change database engines without.
Chapter 8 Using SQL in an Application. Copyright © 2005 Pearson Addison-Wesley. All rights reserved. 8-2 Interactive vs. Non-Interactive SQL Interactive.
1 Java Database Connection (JDBC) There are many industrial-strength DBMS's commercially available in the market. Oracle, DB2, and Sybase are just a few.
Overview of JDBC and Pro*C 1 Overview of JDBC,Pro*C and Oracle connectivity on Omega CSE 5330 – Database Systems.
Database Management Systems 3ed, R. Ramakrishnan and J. Gehrke; edited K. Shomper1 Database Application Development Chapter 6.
Java Database Connectivity (JDBC) Introduction to JDBC JDBC is a simple API for connecting from Java applications to multiple databases. Lets you smoothly.
Javax.sql and java.sql. java.sql Interface Connection public interface Connection extends WrapperWrapper A connection (session) with a specific database.
Announcements Read JDBC Project Step 5, due Monday.
Copyright © 2007 Ramez Elmasri and Shamkant B. Navathe Slide 9- 1 DATADABASE PROGRAMMING 2Chapter 13 from our text.
Chapter 8 Using SQL in an Application. Copyright © 2005 Pearson Addison-Wesley. All rights reserved. 8-2 CSC 4480 outline Intro (3-9) Static SQL (10-11)
JDBC (Java Database Connectivity) SNU OOPSLA Lab. October 2005.
VICTORIA UNIVERSITY OF WELLINGTON Te Whare Wananga o te Upoko o te Ika a Maui COMP 302 Database Systems Java Data Base Connectivity Lecturer Dr Pavle Mogin.
CS 405G: Introduction to Database Systems Database programming.
Overview of JDBC and Pro*C 1 CSE 5330 – Database Systems.
Stored procedures1 Stored procedures and functions Procedures and functions stored in the database.
Advanced SQL: Cursors & Stored Procedures
WEB/DB1 DATABASE PROGRAMMING 3JDBC by the ASU Scholars.
ICS 321 Fall 2010 SQL in a Server Environment (i) Asst. Prof. Lipyeow Lim Information & Computer Science Department University of Hawaii at Manoa 11/1/20101Lipyeow.
Programmatic SQL Shaista Khan CS 157B. Topic Embedded SQL statements in high-level programming languages.
SQL in a Programming Environment CIS 4301 Lecture Notes Lecture /11/2006.
8 1 Chapter 8 Advanced SQL Database Systems: Design, Implementation, and Management, Seventh Edition, Rob and Coronel.
Database Systems Design, Implementation, and Management Coronel | Morris 11e ©2015 Cengage Learning. All Rights Reserved. May not be scanned, copied or.
Chapter 15 Introduction to PL/SQL. Chapter Objectives  Explain the benefits of using PL/SQL blocks versus several SQL statements  Identify the sections.
JDBC Database Programming in Java Prepared by., Mrs.S.Amudha AP/SWE.
JDBC. Java.sql.package The java.sql package contains various interfaces and classes used by the JDBC API. This collection of interfaces and classes enable.
1 CS 430 Database Theory Winter 2005 Lecture 14: Additional SQL Topics.
Chapter 8 Advanced SQL Database Systems: Design, Implementation, and Management, Seventh Edition, Rob and Coronel.
Database Management Systems 3ed, R. Ramakrishnan and J. Gehrke1 Database Application Development Chapter 6 Sections –
Dr Gordon Russell, Napier University Unit Embedde SQL - V2.0 1 Embedded SQL Unit 5.1.
1 Database Application Development Chapter 6 Sections –
Database Access Using JDBC BCIS 3680 Enterprise Programming.
Access Databases from Java Programs via JDBC Tessema M. Mengistu Department of Computer Science Southern Illinois University Carbondale
Text TCS INTERNAL Oracle PL/SQL – Introduction. TCS INTERNAL PL SQL Introduction PLSQL means Procedural Language extension of SQL. PLSQL is a database.
Lu Wei1 Outline Introduction Basic SQL Setting Up and Using PostgreSQL Advanced SQL Embeded SQL.
1 JDBC – Java Database Connectivity CS , Spring 2010.
6/9/2016CENG 352 Database Management Systems1 SQL in the Real World.
CS 440 Database Management Systems Stored procedures & OR mapping 1.
Copyright © 2016 Ramez Elmasri and Shamkant B. Navathe.
SQL in the real world 1. The Three-Tier Architecture of Database Applications browser network HTTP Web server Application server Database server database.
Database Management Systems 3ed, R. Ramakrishnan and J. Gehrke1 Database Application Development Chapter 6.
Chapter 4 An Introduction to SQL. Copyright © 2004 Pearson Addison-Wesley. All rights reserved.4-2 Topics in this Chapter SQL: History and Overview The.
Instructor: Jinze Liu Fall /8/2016Jinze University of Kentucky 2 Database Project Database Architecture Database programming.
1st Semester, 2017 Sanghyun Park
Introduction to SQL Programming Techniques
SQL Environment.
Web Technologies IT230 Dr Mohamed Habib.
Chapter 5: Advanced SQL Database System concepts,6th Ed.
CPSC-310 Database Systems
Database Application Development
DB Programming: SQL Programming Techniques
Unit I-2.
Chapter 8 Advanced SQL.
Lecture 05: SQL Systems Aspects
Presentation transcript:

1 SQL in the Real World Chapter 10

2 Interactive vs. Non-Interactive SQL Interactive SQL: SQL statements input from terminal; DBMS outputs to screen –Inadequate for most uses It may be necessary to process the data before output Amount of data returned not known in advance SQL has very limited expressive power (not Turing- complete) Non-interactive SQL: SQL statements are included in an application program written in a host language, like C, Java, COBOL

3 Application Program Host languageHost language: A conventional language (e.g., C, Java) that supplies control structures, computational capabilities, interaction with physical devices SQL: supplies ability to interact with database. Using the facilities of both: the application program can act as an intermediary between the user at a terminal and the DBMS

4 Preparation Before an SQL statement is executed, it must be prepared by the DBMS: –What indices can be used? –In what order should tables be accessed? –What constraints should be checked? Decisions are based on schema, table sizes, etc. Result is a query execution plan Preparation is a complex activity, usually done at run time, justified by the complexity of query processing

5 Introducing SQL Into the Application SQL statements can be incorporated into an application program in two different ways: –Statement Level Interface (SLI): Application program is a mixture of host language statements and SQL statements and directives –Call Level Interface (CLI): Application program is written entirely in host language SQL statements are values of string variables that are passed as arguments to host language (library) procedures

6 Statement Level Interface SQL statements and directives in the application have a special syntax that sets them off from host language constructs –e.g., EXEC SQL SQL_statement Precompiler scans program and translates SQL statements into calls to host language library procedures that communicate with DBMS Host language compiler then compiles program

7 Statement Level Interface SQL constructs in an application take two forms: –Standard SQL statements (static or embedded SQL): Useful when SQL portion of program is known at compile time –Directives (dynamic SQL): Useful when SQL portion of program not known at compile time. Application constructs SQL statements at run time as values of host language variables that are manipulated by directives Precompiler translates statements and directives into arguments of calls to library procedures.

8 Call Level Interface Application program written entirely in host language (no precompiler) –Examples: JDBC, ODBC SQL statements are values of string variables constructed at run time using host language –Similar to dynamic SQL Application uses string variables as arguments of library routines that communicate with DBMS –e.g. executeQuery (“ SQL query statement ”)

9 Static SQL Declaration section for host/SQL communication Colon convention for value ( WHERE ) and result ( INTO ) parameters EXEC SQL BEGIN DECLARE SECTION ; unsigned long num_enrolled; char crs_code; char SQLSTATE [6]; EXEC SQL END DECLARE SECTION ; ………. EXEC SQL SELECT C.NumEnrolled INTO :num_enrolled Course FROM Course C WHERE C.CrsCode = :crs_code; Variables shared by host and SQL “:” used to set off host variables

10 Status EXEC SQL SELECT C.NumEnrolled INTO :num_enrolled Course FROM Course C WHERE C.CrsCode = :crs_code; if ( !strcmp ( SQLSTATE, “00000”) ) { printf ( “statement failed” ) }; In parameter Out parameter

11 Connections To connect to an SQL database, use a connect statement CONNECT TO database_name AS connection_name USING user_id

12 Transactions No explicit statement is needed to begin a transaction –A transaction is initiated when the first SQL statement that accesses the database is executed The mode of transaction execution can be set with SET TRANSACTION READ ONLY ISOLATION LEVEL SERIALIZABLE Transactions are terminated with COMMIT or ROLLBACK statements

13 Example: Course Deregistration EXEC SQL CONNECT TO :dbserver; if ( ! strcmp ( SQLSTATE, “00000”) ) exit (1); ….. Transcript EXEC SQL DELETE FROM Transcript T WHERE T.StudId = :studid AND T.Semester = ‘S2000’ AND T.CrsCode = :crscode; if (! strcmp ( SQLSTATE, “00000”) ) EXEC SQL ROLLBACK; else { Course EXEC SQL UPDATE Course C SET C.Numenrolled = C.Numenrolled – 1 WHERE C.CrsCode = :crscode; if (! strcmp ( SQLSTATE, “00000”) ) EXEC SQL ROLLBACK ; else EXEC SQL COMMIT ; }

14 Buffer Mismatch Problem Problem: SQL deals with tables (of arbitrary size); host language program deals with fixed size buffers –How is the application to allocate storage for the result of a SELECT statement? Solution: Fetch a single row at a time –Space for a single row (number and type of out parameters) can be determined from schema and allocated in application

15 Cursors Result set – set of rows produced by a SELECT statement Cursor – pointer to a row in the result set. Cursor operations: –Declaration –Open – execute SELECT to determine result set and initialize pointer –Fetch – advance pointer and retrieve next row –Close – deallocate cursor

16 Cursors (cont’d) SELECT cursor Base table Result set (or pointers to it) application

17 Cursors (cont’d) DECLARE GetEnroll EXEC SQL DECLARE GetEnroll INSENSITIVE CURSOR FOR SELECT T.StudId, T.Grade --cursor is not a schema element Transcript FROM Transcript T WHERE T.CrsCode = :crscode AND T.Semester = ‘S2000’; ……… OPEN EXEC SQL OPEN GetEnroll; if ( !strcmp ( SQLSTATE, “00000”)) {... fail exit... }; ………. FETCH EXEC SQL FETCH GetEnroll INTO :studid, :grade; while ( SQLSTATE = “00000”) { … process the returned row... FETCH GetEnroll EXEC SQL FETCH GetEnroll INTO :studid, :grade; } if ( !strcmp ( SQLSTATE, “02000”)) {... fail exit... }; ………. CLOSE EXEC SQL CLOSE GetEnroll; Reference resolved at compile time, Value substituted at OPEN time

18 Cursor Types Insensitive cursor: Result set (effectively) computed and stored in a separate table at OPEN time –Changes made to base table subsequent to OPEN (by any transaction) do not affect result set –Cursor is read-only Cursors that are not insensitive: Specification not part of SQL standard –Changes made to base table subsequent to OPEN (by any transaction) can affect result set –Cursor is updatable

19 Insensitive Cursor key1 t t t t t t t t key1 t t t t qqt t t t key3 yyyyyyyy key2 xxxxxxxxx key4 zzzzzzzzz key3 yyyrryyyy key4 zzzzzzzzzz key5 uuuuuuuuu key6 vvvvvvvvv Base Table cursor Result Set Tuples added after opening the cursor Changes made after opening cursor not seen in the cursor

20 Keyset-Driven Cursor Example of a cursor that is not insensitive Primary key of each row in result set is computed at open time UPDATE or DELETE of a row in base table by a concurrent transaction between OPEN and FETCH might be seen through cursor INSERT into base table, however, not seen through cursor Cursor is updatable

21 Keyset-Driven Cursor key1 key1 t t t t t t t t t t key3 key2 xxxxxxxxxxx key4 key3 yyyyyyyyyyy key4 zzzzzzzzzzzz key5 uuuuuuuuuuu key6 vvvvvvvvvvv Base table Cursor Key set Tuples added after cursor is open are not seen, but updates to key1, key3, key4 are seen in the cursor.

22 Cursors INSENSITIVESCROLL DECLARE cursor-name [INSENSITIVE] [SCROLL] CURSOR FOR table-expr [ ORDER BY column-list ] READ ONLYUPDATE [ FOR {READ ONLY | UPDATE [ OF column-list ] } ] For updatable (not insensitive, not read-only) cursors UPDATE table-name --base table SET assignment WHERE CURRENT OF cursor-name DELETE FROM table-name --base table WHERE CURRENT OF cursor-name Restriction – table-expr must satisfy restrictions of updatable view

23 Scrolling If SCROLL option not specified in cursor declaration, FETCH always moves cursor forward one position If SCROLL option is included in DECLARE CURSOR section, cursor can be moved in arbitrary ways around result set: PRIOR GetEnroll FETCH PRIOR FROM GetEnroll INTO :studid, :grade; Also: FIRST, LAST, ABSOLUTE n, RELATIVE n Get previous tuple

24 Stored Procedures Procedure – written in a conventional algorithmic language –Included as schema element (stored in DBMS) –Invoked by the application Advantages: –Intermediate data need not be communicated to application (time and cost savings) –Procedure’s SQL statements prepared in advance –Authorization can be done at procedure level –Added security since procedure resides in server –Applications that call the procedure need not know the details of database schema – all database access is encapsulated within the procedure

25 Stored Procedures Call P P In/out arguments Application (client) P Intermediate results DBMS (server) Network connection table Regular procedure Stored procedure

26 Stored Procedures CREATE PROCEDURE CREATE PROCEDURE Register (char :par1, char :par2) AS BEGIN EXEC SQL SELECT ……. ; IF ( ……) THEN …… -- SQL embedded in ELSE …. -- Persistent Stored Modules -- (PSM) language END EXECUTE PROCEDURE EXEC SQL EXECUTE PROCEDURE Register ( :crscode, :studid); Schema : Application :

27 Integrity Constraint Checking Transaction moves database from an initial to a final state, both of which satisfy all integrity constraints but... –Constraints might not be true of intermediate states hence … –Constraint checks at statement boundaries might be inappropriate SQL (optionally) allows checking to be deferred to transaction COMMIT

28 Deferred Constraint Checking Schema : NumberEnrolled CREATE ASSERTION NumberEnrolled CHECK ( …….) DEFERRABLE DEFERRABLE; Application : NumberEnrolled DEFERRED SET CONSTRAINT NumberEnrolled DEFERRED; Transaction is aborted if constraint is false at commit time

29 Dynamic SQL Problem: Application might not know in advance : –The SQL statement to be executed –The database schema to which the statement is directed Example: User inputs database name and SQL statement interactively from terminal In general, application constructs (as the value of a host language string variable) the SQL statement at run time Preparation (necessarily) done at run time

30 Dynamic SQL SQL-92 defines syntax for embedding directives into application for constructing, preparing, and executing an SQL statement –Referred to as Dynamic SQL –Statement level interface Dynamic and static SQL can be mixed in a single application

31 Dynamic SQL stst is an SQL variable; names the SQL statement tmpcrscodenum_enrolledtmp, crscode, num_enrolled are host language variables (note colon notation) crscodecrscode is an in parameter; supplies value for placeholder ( ? ) num_enrollednum_enrolled is an out parameter; receives value from C.NumEnrolled Course strcpy (tmp, “ SELECT C.NumEnrolled FROM Course C \ WHERE C.CrsCode = ? ” ) ; PREPARE EXEC SQL PREPARE st FROM :tmp ; EXECUTE EXEC SQL EXECUTE st INTO :num_enrolled USING :crs_code; placeholder

32 Dynamic SQL stPREPARE names SQL statement st and sends it to DBMS for preparation stEXECUTE causes the statement named st to be executed

33 Parameters: Static vs Dynamic SQL Static SQL:Static SQL: –Names of (host language) parameters are contained in SQL statement and available to precompiler –Address and type information in symbol table –Routines for fetching and storing argument values can be generated –Complete statement (with parameter values) sent to DBMS when statement is executed EXEC SQL SELECT C.NumEnrolled INTO INTO :num_enrolled Course FROM Course C WHERE C.CrsCode = :crs_code;

34 Parameters: Static vs. Dynamic SQL Dynamic SQLDynamic SQL: SQL statement constructed at run time when symbol table is no longer present Case 1: Parameters are known at compile time –Parameters are named in EXECUTE statement: in parameters in USING; out parameters in INTO clauses –EXECUTE statement is compiled using symbol table fetch() and store() routines generated Course strcpy (tmp, “ SELECT C.NumEnrolled FROM Course C \ WHERE C.CrsCode = ?” ) ; PREPARE EXEC SQL PREPARE st FROM :tmp ; EXECUTEINTO EXEC SQL EXECUTE st INTO :num_enrolled USING :crs_code;

35 Parameters – Dynamic SQL (Case 1: parameters known at compile time) –Fetch and store routines are executed at client when EXECUTE is executed to communicate argument values with DBMS –EXECUTE can be invoked multiple times with different values of in parameters Each invocation uses same query execution plan –Values substituted for placeholders by DBMS (in order) at invocation time and statement is executed

36 Parameters in Dynamic SQL (parameters supplied at runtime) Case 2: Parameters not known at compile time Example: Statement input from terminal –Application cannot parse statement and might not know schema, so it does not have any parameter information EXECUTE statement cannot name parameters in INTO and USING clauses

37 Parameters in Dynamic SQL (cont’d) (Case 2: parameters supplied at runtime) –DBMS determines number and type of parameters after preparing the statement –Information stored by DBMS in a descriptor – a data structure inside the DBMS, which records the name, type, and value of each parameter –Dynamic SQL provides directive GET DESCRIPTOR to get information about parameters (e.g., number, name, type) from DBMS and to fetch value of out parameters –Dynamic SQL provides directive SET DESCRIPTOR to supply value to in parameters

38 Descriptors Course temp = “ SELECT C.NumEnrolled, C.Name FROM Course C \ WHERE C.CrsCode = ‘CS305’ ” 60 NumEnrolled integer “ Databases ” Name string DBMS application GET DESCRIPTOR 1. Application uses GET DESCRIPTOR to fetch name, type, value 2. Then gets value into appropriate host variable 3. Then processes value value name type value name type Descriptor

39 Dynamic SQL Calls when Descriptors are Used … … construct SQL statement in temp …… PREPARE EXEC SQL PREPARE st FROM :temp; // prepare statement ALLOCATE DESCRIPTOR EXEC SQL ALLOCATE DESCRIPTOR ‘desc’; // create descriptor DESCRIBE OUTPUT EXEC SQL DESCRIBE OUTPUT st USING SQL DESCRIPTOR ‘desc’; // populate desc with info out // about out parameters EXECUTE EXEC SQL EXECUTE st INTO // execute statement and out SQL DESCRIPTOR AREA ‘desc’; // store out values in desc GET DESCRIPTOR out EXEC SQL GET DESCRIPTOR ‘desc’ …; // get out values in … … similar strategy is used for in parameters … …

40 Example: Nothing Known at Compile Time sprintf(my_sql_stmt, “ SELECT * FROM %s WHERE COUNT (*) = 1”, table); // table – host var; even the table is known only at run time! EXEC SQL PREPARE st FROM :my_sql_stmt; EXEC SQL ALLOCATE DESCRIPTOR ‘st_output’; EXEC SQL DESCRIBE OUTPUT st USING SQL DESCRIPTOR ‘st_output’ –The SQL statement to execute is known only at run time out –At this point DBMS knows what the exact statement is (including the table name, the number of out parameters, their types) st_output out –The above statement asks to create descriptors in st_output for all the (now known) out parameters EXEC SQL EXECUTE st INTO SQL DESCRIPTOR ‘st_output’;

41 Example: Getting Meta-Information from a Descriptor out // Host var colcount gets the number of out parameters in the SQL statement // described by st_output COUNT EXEC SQL GET DESCRIPTOR ‘st_output’ :colcount = COUNT; // Set host vars coltype, collength, colname with the type, length, and name of the out // colnumber’s out parameter in the SQL statement described by st_output EXEC SQL GET DESCRIPTOR ‘ st_output ’ VALUE :colnumber; TYPE :coltype = TYPE, // predefined integer constants, such as SQL_CHAR, SQL_FLOAT,… LENGTH :collength = LENGTH, NAME :colname = NAME ;

42 Example: Using Meta-Information to Extract Attribute Value char strdata[1024]; int intdata; … … … switch ( coltype ) { case SQL_CHAR: DATA EXEC SQL GET DESCRIPTOR ‘st_output’ VALUE :colnumber :strdata =DATA ; break ; case SQL_INT: DATA ; EXEC SQL GET DESCRIPTOR ‘st_output’ VALUE :colnumber :intdata =DATA ; break ; case SQL_FLOAT: … … … } Put the value of attribute colnumber into the variable strdata

43 JDBC Call-level interface (CLI) for executing SQL from a Java program SQL statement is constructed at run time as the value of a Java variable (as in dynamic SQL) JDBC passes SQL statements to the underlying DBMS. Can be interfaced to any DBMS that has a JDBC driver

44 JDBC Run-Time Architecture DBMS application driver manager DB/2 driver SQLServer driver Oracle driver DB/2 database SQLServer database Oracle database

45 Executing a Query import java.sql.*; -- import all classes in package java.sql Class.forName (driver name); // static method of class Class // loads specified driver Connection con = DriverManager.getConnection(Url, Id, Passwd); Static method of class DriverManager; attempts to connect to DBMS If successful, creates a connection object, con, for managing the connection Statement stat = con.CreateStatement (); Creates a statement object stat Statements have executeQuery() method

46 Executing a Query Transcript String query = “SELECT T.StudId FROM Transcript T” + “WHERE T.CrsCode = ‘cse305’ ” + “AND T.Semester = ‘S2000’ ”; ResultSet res = stat.executeQuery (query); Creates a result set object, res. Prepares and executes the query. Stores the result set produced by execution in res (analogous to opening a cursor). The query string can be constructed at run time (as above). The input parameters are plugged into the query when the string is formed (as above)

47 Transcript String query = “SELECT T.StudId FROM Transcript T” + “WHERE T.CrsCode = ? AND T.Semester = ?”; PreparedStatement ps = con.prepareStatement ( query ); Prepares the statement Creates a prepared statement object, ps, containing the prepared statement Placeholdersin Placeholders (?) mark positions of in parameters; special API is provided to plug the actual values in ? positions indicated by the ?’s Preparing and Executing a Query placeholders

48 Preparing and Executing a Query String crs_code, semester; ……… in ps.setString(1, crs_code); // set value of first in parameter in ps.setString(2, semester); // set value of second in parameter ResultSet res = ps.executeQuery ( ); Creates a result set object, res Executes the query Stores the result set produced by execution in res while ( res.next ( ) ) { // advance the cursor j = res.getInt (“StudId”); // fetch output int-value …process output value… }

49 Result Sets and Cursors Three types of result sets in JDBC: –Forward-only: not scrollable –Scroll-insensitive: scrollable, changes made to underlying tables after the creation of the result set are not visible through that result set –Scroll-sensitive: scrollable, changes made to the tuples in a result set after the creation of that set are visible through the set

50 Result Set Any result set type can be declared read-only or updatable – CONCUR_UPDATABLE (assuming SQL query satisfies the conditions for updatable views) Current row of an updatable result set can be updated or deleted, and a new row can be inserted, causing changes in base table Statement stat = con.createStatement ( ResultSet. TYPE_SCROLL_SENSITIVE, ResultSet. CONCUR_UPDATABLE ); res.updateString (“Name”, “John” ); // update attribute “Name” of // current row in row buffer. res.updateRow ( ); // install current row buffer in res and underlying table

51 Handling Exceptions try/catch is the basic structure within which an SQL statement should be embedded If an exception is thrown, an exception object, ex, is created and the catch clause is executed The exception object has methods to print an error message, return SQLSTATE, etc. try {...Java/JDBC code... } catch ( SQLException ex ) { …exception handling code... }

52 Transactions in JDBC Default for a connection is –Transaction boundaries Autocommit mode: each SQL statement is a transaction. To group several statements into a transaction use con.setAutoCommit (false) –Isolation default isolation level of the underlying DBMS To change isolation level use con.setTransactionIsolationLevel ( TRANSACTION_SERIALIZABLE ) With autocommit off: –transaction is committed using con.commit(). –next transaction is automatically initiated (chaining) Transactions on each connection committed separately

53 SQLJ A statement-level interface to Java –A dialect of embedded SQL designed specifically for Java –Translated by precompiler into Java –SQL constructs translated into calls to an SQLJ runtime package, which accesses database through calls to a JDBC driver

54 SQLJ Has some of efficiencies of embedded SQL –Compile-time syntax and type checking –Use of host language variables –More elegant than embedded SQL Has some of the advantages of JDBC –Can access multiple DBMSs using drivers –SQLJ statements and JDBC calls can be included in the same program

55 SQLJ Example #SQL { SELECT C.Enrollment INTO :numEnrolled Class FROM Class C WHERE C.CrsCode = :crsCode AND C.Semester = :semester };

56 Example of SQLJ Iterator #SQL iterator GetEnrolledIter (int studentId, String studGrade); GetEnrolledIter iter1; #SQL iter1 = { SELECT T.StudentId as “studentId”, T.Grade as “studGrade” Transcript FROM Transcript T WHERE T.CrsCode = :crsCode AND T.Semester = :semester }; Method names by which to access the attributes StudentId and Grade

57 Iterator Example (cont’d) int id; String grade; while ( iter1.next( ) ) { id = iter1.studentId(); grade = iter1.studGrade(); … process the values in id and grade … }; iter1.close();

58 ODBC Call level interface that is database independent Related to SQL/CLI, part of SQL:1999 Software architecture similar to JDBC with driver manager and drivers Not object oriented Low-level: application must specifically allocate and deallocate storage

59 Sequence of Procedure Calls Needed for ODBC SQLAllocEnv(&henv); // get environment handle SQLAllocConnect(henv, &hdbc); // get connection handle SQLConnect(hdbc, db_name, userId, password); // connect SQLAllocStmt(hdbc, &hstmt); // get statement handle SQLPrepare(hstmt, SQL statement); // prepare SQL statement SQLExecute(hstmt); SQLFreeStmt(hstmt); // free up statement space SQLDisconnect(hdbc); SQLFreeEnv(henv); // free up environment space

60 ODBC Features Cursors –Statement handle (for example hstmt) is used as name of cursor Status Processing –Each ODBC procedure is actually a function that returns status RETCODE retcode1; Retcode1 = SQLConnect ( …) Transactions –Can be committed or aborted with SQLTransact (henv, hdbc, SQL_COMMIT)