Presentation is loading. Please wait.

Presentation is loading. Please wait.

1 Section 10 - Embedded SQL u Many computer languages allow you to embed SQL statements within the code (e.g. COBOL, PowerBuilder, C++, PL/SQL, etc.) u.

Similar presentations


Presentation on theme: "1 Section 10 - Embedded SQL u Many computer languages allow you to embed SQL statements within the code (e.g. COBOL, PowerBuilder, C++, PL/SQL, etc.) u."— Presentation transcript:

1 1 Section 10 - Embedded SQL u Many computer languages allow you to embed SQL statements within the code (e.g. COBOL, PowerBuilder, C++, PL/SQL, etc.) u This allows you to both… –pass program variables to SQL statements –receive SQL statement results into program variables

2 2 Embedded SQL Keywords u There are special SQL keywords that only have meaning with Embedded SQL –INTO –FETCH –DECLARE CURSOR –OPEN CURSOR –CLOSE CURSOR

3 3 SQL Status Checking u A major difference between Interactive SQL and Embedded SQL is that you must explicitly check for the success or failure of each SQL statement. u Program logic may change based on the return values from SQL statements u Transaction management may change base on the return values from SQL statements

4 4 Publishers Table u For this presentation, we will use the publishers table from the bookbiz.db database u PUBLISHERS: pub_idvarchar(4)not null pub_namevarchar(40)not null addressvarchar(40) cityvarchar(20) statechar(2)

5 5 Publishers Table Data u Pub_idPub_nameAddressCity State 0736New Age Books1 1st St.Boston MA 0877Binnet & Hardley2 2nd St.Houston TX 1389Algodata Systems3 3rd St.Berkeley CA

6 6 Interactive SQL Example u SELECT pub_id, pub_name, state FROM publishers WHERE pub_name = 'New Age Books'; u Returns: 0736 New Age Books MA

7 7 Using PowerBuilder u For the rest of this presentation we will be using PowerBuilder scripting to illustrate the embedded SQL examples u Other languages may vary in how you specify variable name within a SQL statement u I will be teaching you a few Powerbuilder scripting statements in this presentation

8 8 The INTO clause u In embedded SQL we use an INTO clause in the SELECT statement to receive information into program variables u SELECT select_list INTO variable_list FROM table_list [ Rest of Statement ];

9 9 Embedded SQL Example u SELECT pub_id, pub_name, state INTO :ls_pub_id, :ls_pub_name, :ls_state FROM publishers WHERE pub_name = 'New Age Books'; Messagebox("Pub_id for New Age Books", ls_pub_id) u In PowerBuilder, variable names that appear within SQL statements are preceded with a colon ( : )

10 10 Exercise u Write the code to display the average price of books in a Messagebox window.

11 11 Discussion u Integer li_price SELECT AVG(price) INTO :li_price FROM titles Messagebox('Average Price', li_price)

12 12 Exercise u Display in a Messagebox the publisher name for the book "Life Without Fear" (Note: Do not use any join operations or subqueries! )

13 13 Discussion u String ls_pubname, ls_pub_id SELECT pub_id INTO :ls_pub_id FROM titles WHERE title = 'Life Without Fear'; SELECT pub_name into :ls_pub_name FROM publishers WHERE pub_id = :ls_pub_id Messagebox('Publisher', ls_pub_name)

14 14 Multiple Return Rows u Preceding SELECT statement examples returned only one row u What do you think will happen if an embedded SELECT returns more than one row?

15 15 Interactive vs. Embedded u Interactive: –SELECT pub_id, pub_name, state FROM publishers WHERE state LIKE '_A'; –Returns two rows u Embedded: –SELECT pub_id, pub_name, state INTO :ls_pub_id, :ls_pub_name, :ls_state FROM publishers WHERE state LIKE '_A'; –Error Condition!

16 16 Why? u You've only provided one set of variables for two rows of information –i.e. you can't stuff two pub_names (from the two rows returned) into :ls_pub_name

17 17 Buffering Returned Data u If there is any possibility that a SELECT statement will return more than one row you must provide a buffer to hold the values u DECLARE CURSOR creates this buffer u This buffer will be read later (one row at a time) using the FETCH statement

18 18 DECLARE CURSOR Syntax u DECLARE CURSOR FOR ; u Example: –DECLARE pub_cursor CURSOR FOR SELECT pub_id, pub_name, state FROM publishers WHERE state LIKE '_A';

19 19 Open the Cursor u The DECLARE CURSOR stores the associated SELECT statement, but does not execute it. u The OPEN statement actually executes the stored SELECT statement u Example: –OPEN pub_cursor;

20 20 Getting the Buffered Data u The OPEN cursor statement retrieves the rows into the buffer u How do we get this information into the program variables?

21 21 FETCH INTO Statement u To read the buffer one row at a time and get the data into program variables, use the FETCH INTO statement u Syntax: FETCH INTO u Example: FETCH pub_cursor INTO :ls_pub_id, :ls_pub_name, :ls_state;

22 22 Matching Variables & Columns u The variables declared in the FETCH INTO statement... –must be equal to the number of columns in the SELECT statement saved with the cursor –must be of the same datatype (or convert to the variable datatype)

23 23 Program Loops u In order to get all the rows in the buffer you must execute the FETCH statement each time you want to get the next row u Place the FETCH in a program loop and exit the loop when there are now more rows to read in the buffer

24 24 Example u DO FETCH pub_cursor INTO :ls_pub_id, :ls_pub_name, ls_state; If sqlca.sqlcode = 100 then EXIT end if LOOP WHILE TRUE

25 25 SQLcode u The sqlca.sqlcode variable you saw in the preceding statement is a PowerBuilder specific variable name that stores the return value from an executed SQL statement u Notice that variables within the programming language, (i.e. not in the SQL statement proper), are not preceded with the colon

26 26 Status Checking u All embedded SQL statements should have there status checked by interrogated the return code (e.g. sqlca.sqlcode) u Return codes and their meaning... –0 means success for all statements including the INSERT, UPDATE & DELETE when no rows are affected –100 means no rows found for the SELECT and means at end of buffer for the FETCH –-1 (minus one) means database error

27 27 Example u FETCH pub_cursor INTO :ls_pub_id, :ls_pub_name, ls_state; CHOOSE CASE sqlca.sqlcode CASE 0 COMMIT: CASE 100 COMMIT; EXIT CASE -1 ROLLBACK; Messagebox("Database Error", "Process Halted") HALT END CHOOSE

28 28 COMMIT and ROLLBACK u Remember… –COMMIT saves the updates to the database since the last COMMIT –ROLLBACK un-does the updates to the database since the last COMMIT

29 29 Close the cursor u To clear the buffer to a close the cursor u Syntax: CLOSE u Example: CLOSE pub_cursor;

30 30 Example - Embedded INSERT u String ls_test_name ls_test_name = 'Perry Publishing' u INSERT INTO publishers (pub_id, pub_name) VALUES ('9988', :ls_test_name); u When using a constant do not use a colon

31 31 Example - Embedded UPDATE u string ls_state ls_state = 'CA' u UPDATE publishers SET city = 'Oakland', state = :ls_state WHERE pub_name = :ls_test_name;

32 32 PowerBuilder Scripting u The following are some PowerBuilder scripting statements that may help you completed the assignment.

33 33 Declaring a Variable u String –For character based data –example: String ls_last_name u Int –for whole numbers less than 32674 –example: Int li_count

34 34 Displaying Information u MessageBox(, ) –example: String ls_msg ls_msg = 'Something is wrong' MessageBox("Error Found", ls_msg)

35 35 DO Loop u Executes the script inside the Loop repetitively u Example: Do li_count = li_count + 1 Loop While True u This will add 1 to li_count continually

36 36 Leaving a Loop u EXIT –Leaves the current loop (e.g DO-LOOP) and continues with the next line of code after the loop –example: DO li_count = li_count + 1 if li_count > 4 then EXIT end if LOOP WHILE TRUE Messagebox("Info","Completed")

37 37 Stopping Execution u RETURN leaves the currently running script u HALT terminates the entire application

38 38 Decision Logic u If-Then-Else –example:If li_count > 1 then li_count = 0 else li_count = 1 end if u Choose Case –example:Choose Case li_count Case > 1 li_count = 0 Case Else li_count = 1 End Choose

39 39 End Section 10 - Embedded SQL u Embedded SQL Assignment is Optional. u Due: Whenever (e-mail me the code) u There are no points added to your grade for this assignment u Use any programming language that allow embedded SQL… That means Not Visual Basic!


Download ppt "1 Section 10 - Embedded SQL u Many computer languages allow you to embed SQL statements within the code (e.g. COBOL, PowerBuilder, C++, PL/SQL, etc.) u."

Similar presentations


Ads by Google