In this tutorial, you will use SQL Developer to create objects for a
simplified library database, which will include tables for books,
patrons (people who have library cards), and transactions (checking a
book out, returning a book, and so on).
Note:
Other SQL Developer tutorials, including Oracle By Example (OBE)
lessons, are available from the Start Page. If the tab for that page is
not visible, click
Help, then
Start Page.
The tables are deliberately oversimplified for this tutorial. They
would not be adequate for any actual public or organizational library.
For example, this library contains only books (not magazines, journals,
or other document formats), and it can contain no more than one copy of
any book.
You will perform the following major steps:
-
-
-
-
-
-
-
-
-
Section 4.10, "Script for Creating and Using the Library Tutorial Objects"
Chapter 1, "SQL Developer Concepts and Usage"
Section 1.2, "SQL Developer User Interface"
Section 1.3, "Database Objects"
4.1 Create a Table (BOOKS)
The BOOKS table contains a row for each book in the library. It
includes columns of character and number types, a primary key, a unique
constraint, and a check constraint. You will use the Create Table dialog
box to create the table declaratively; the table that you create will
be essentially the same as if you had entered the following statement
using the SQL Worksheet:
CREATE TABLE books (
book_id VARCHAR2(20),
title VARCHAR2(50)
CONSTRAINT title_not_null NOT NULL,
author_last_name VARCHAR2(30)
CONSTRAINT last_name_not_null NOT NULL,
author_first_name VARCHAR2(30),
rating NUMBER,
CONSTRAINT books_pk PRIMARY KEY (book_id),
CONSTRAINT rating_1_to_10 CHECK (rating IS NULL OR
(rating >= 1 and rating <= 10)),
CONSTRAINT author_title_unique UNIQUE (author_last_name, title));
To create the BOOKS table, connect to the database as the user in the
schema you want to use for this tutorial. Right-click the Tables node
in the schema hierarchy on the left side, select
New Table,
and enter the following information. (If a tab or field is not
mentioned, do not enter anything for it. Be sure that the Advanced box
is not checked when you start creating the table.)
For detailed information about the table dialog box and its tabs, see
Section 5.52, "Create Table (quick creation)" and
Section 5.53, "Create/Edit Table (with advanced options)".
Schema: Specify your current schema as the schema in which to create the table.
Name: BOOKS
Create the table columns using the following information. After creating each column except the last one (rating), click
Add Column
to add the next column. (If you accidentally click OK instead of Add
Column, right-click the BOOKS table in the Connections navigator
display, select Edit, and continue to add columns.)
After you have entered the last column (rating), check
Advanced
(next to Schema). This displays a pane for more table options. For this
table, you will use the Unique Constraints and Check Constraints panes.
Click
Add to add a unique constraint for
the table, namely, that the combination of author_last_name and title
must be unique within the table. (This is deliberately oversimplified,
since most major libraries will have allow more than one copy of a book
in their holdings. Also, the combination of last name and title is not
always a "foolproof" check for uniqueness, but it is sufficient for this
simple scenario.)
Name: author_title_unique
In
Available Columns, double-click TITLE and then AUTHOR_LAST_NAME to move them to Selected Columns.
Click
Add to add a check constraint for the
table, namely, that the rating column value is optional (it can be
null), but if a value is specified, it must be a number from 1 through
10. You must enter the condition using SQL syntax that is valid in a
CHECK clause (but do not include the CHECK keyword or enclosing
parentheses for the entire CHECK clause text).
Name: rating_1_to_10
Condition: rating is null or (rating >= 1 and rating <= 10)
Click
OK to finish creating the table.
Go to
Section 4.2, "Create a Table (PATRONS)" to create the next table.
4.2 Create a Table (PATRONS)
The PATRONS table contains a row for each patron who can check books
out of the library (that is, each person who has a library card). It
includes an object type (MDSYS.SDO_GEOMETRY) column. You will use the
Create Table dialog box to create the table declaratively; the table
that you create will be essentially the same as if you had entered the
following statement using the SQL Worksheet:
CREATE TABLE patrons (
patron_id NUMBER,
last_name VARCHAR2(30)
CONSTRAINT patron_last_not_null NOT NULL,
first_name VARCHAR2(30),
street_address VARCHAR2(50),
city_state_zip VARCHAR2(50),
location MDSYS.SDO_GEOMETRY,
CONSTRAINT patrons_pk PRIMARY KEY (patron_id));
The use of single city_state_zip column for all that information is
not good database design; it is done here merely to simplify your work
in the tutorial.
The location column (Oracle Spatial geometry representing the
patron's geocoded address) is merely to show the use of a complex
(object) type.
To create the PATRONS table, if you are not already connected,
connect to the database as the user for the schema you are using for
this tutorial. Right-click the Tables node in the schema hierarchy on
the left side, select
New Table, and enter the
following information. (If a tab or field is not mentioned, do not
enter anything for it. Be sure that the Advanced box is not checked when
you start creating the table.)
Schema: Specify your current schema as the schema in which to create the table.
Name: PATRONS
Create most of the table columns using the following information.
After creating each column except the city_state_zip column, click
Add Column
to add the next column. (If you accidentally click OK instead of Add
Column, right-click the PATRONS table in the Connections navigator
display, select Edit, and continue to add columns.)
The last column in the table (location) requires a complex data type,
for which you must use the Columns tab with advanced options. Check
Advanced (next to Schema). This displays a pane for selecting more table options.
In the Columns pane, click the city_state_zip column name, and click the Add Column (
+) icon to add the following as the last column in the table.
After you have entered the last column (location), click
OK to finish creating the table.
Go to
Section 4.3, "Create a Table (TRANSACTIONS)" to create the next table.
4.3 Create a Table (TRANSACTIONS)
The TRANSACTIONS table contains a row for each transaction involving a
patron and a book (for example, someone checking a book out or
returning a book). It includes two foreign key columns. You will use the
Create Table dialog box to create the table declaratively; the table
that you create will be essentially the same as if you had entered the
following statement using the SQL Worksheet:
CREATE TABLE transactions (
transaction_id NUMBER,
patron_id CONSTRAINT for_key_patron_id
REFERENCES patrons(patron_id),
book_id CONSTRAINT for_key_book_id
REFERENCES books(book_id),
transaction_date DATE
CONSTRAINT tran_date_not_null NOT NULL,
transaction_type NUMBER
CONSTRAINT tran_type_not_null NOT NULL,
CONSTRAINT transactions_pk PRIMARY KEY (transaction_id));
To create the TRANSACTIONS table, if you are not already connected,
connect to the database as the user for the schema you are using for
this tutorial. Right-click the Tables node in the schema hierarchy on
the left side, select
New Table, and enter the
following information. (If a tab or field is not mentioned, do not
enter anything for it. Be sure that the Advanced box is not checked when
you start creating the table.)
Schema: Specify your current schema as the schema in which to create the table.
Name: TRANSACTIONS
Create the table columns using the following information. After
creating each column except the last one (transaction_type), click
Add Column
to add the next column. (If you accidentally click OK instead of Add
Column, right-click the TRANSACTIONS table in the Connections navigator
display, select Edit, and continue to add columns.)
After you have entered the last column (transaction_type), check
Advanced
(next to Schema). This displays a pane for selecting more table
options. For this table, you will use the Column Sequences and Foreign
Keys panes.
You have already specified TRANSACTION_ID as the primary key, and you
will use this pane only to specify that the primary key column values
are to be populated automatically. This convenient approach uses a
trigger and a sequence (both created automatically by SQL Developer),
and ensures that each transaction ID value is unique.
Column: TRANSACTION_ID
Sequence: New Sequence
Trigger: TRANSACTIONS_TRG (The default; a before-insert trigger with this name will be created automatically.)
1. Click
Add to create the first of the two foreign keys for the TRANSACTIONS table.
Name: for_key_patron_id
Referenced Schema: Name of the schema
containing the table with the primary key or unique constraint to which
this foreign key refers. Use the schema you have been using for this
tutorial.
Referenced Table: PATRONS
Referenced Constraint: PATRONS_PK (The name of the primary key constraint for the PATRONS table. Be sure that the
Referenced Column on PATRONS displayed value is PATRON_ID.)
Associations: Local Column: PATRON_ID
Associations: Referenced Column on PATRONS: PATRON_ID
2. Click
Add to create the second of the two foreign keys for the TRANSACTIONS table.
Name: for_key_book_id
Referenced Schema: Name of the schema
containing the table with the primary key or unique constraint to which
this foreign key refers. Use the schema you have been using for this
tutorial.
Referenced Table: BOOKS
Referenced Constraint: BOOKS_PK (The name of the primary key constraint for the BOOKS table. Be sure that the
Referenced Column on BOOKS displayed value is BOOK_ID.
Associations: Local Column: BOOK_ID
Associations: Referenced Column on BOOKS: BOOK_ID
3. Click
OK to finish creating the table.
You have finished creating all the tables. To create a sequence for
use in generating unique primary key values for the PATRONS table, go to
Section 4.4, "Create a Sequence".
4.4 Create a Sequence
Create one sequence object, which will be used in INSERT statements
to generate unique primary key values in the PATRONS table. (You do not
need to create a sequence for the primary key in the TRANSACTIONS table,
because you used the SQL Developer feature that enables automatic
population of primary key values for that table.) You will use the
Create Sequence dialog box to create the sequence declaratively; the
sequence that you create will be essentially the same as if you had
entered the following statements using the SQL Worksheet:
CREATE SEQUENCE patron_id_seq
START WITH 100
INCREMENT BY 1;
After creating the sequence, you can use it in INSERT statements to
generate unique numeric values. The following example uses the
patron_id_seq sequence in creating a row for a new patron (library
user), assigning her a patron ID that is the next available value of the
patron_id_seq sequence:
INSERT INTO patrons VALUES (patron_id_seq.nextval,
'Smith', 'Jane', '123 Main Street', 'Mytown, MA 01234', null);
To create the sequence, if you are not already connected, connect to
the database as the user for the schema you are using for this tutorial.
Right-click the Sequences node in the schema hierarchy on the left
side, select
New Sequence, and enter information using the Create Sequence dialog box.
Schema: Specify your current schema as the schema in which to create the sequence.
Name: patron_id_seq
Increment: 1
Start with: 100
Min value: 100
Click
OK to finish creating the sequence.
To insert sample data into the tables, go to
Section 4.5, "Insert Data into the Tables".
4.5 Insert Data into the Tables
For your convenience in using the view and the PL/SQL procedure that
you will create, add some sample data to the BOOKS, PATRONS, and
TRANSACTIONS tables. (If you do not add sample data, you can still
create the remaining objects in this tutorial, but the view and the
procedure will not return any results.)
Go to the SQL Worksheet window associated with the database
connection you have been using. (For information about using the SQL
Worksheet, see
Section 1.7, "Using the SQL Worksheet".) Copy and paste the following INSERT statements into the
Enter SQL Statement box:
INSERT INTO books VALUES ('A1111', 'Moby Dick', 'Melville', 'Herman', 10);
INSERT INTO books VALUES ('A2222', 'Get Rich Really Fast', 'Scammer', 'Ima', 1);
INSERT INTO books VALUES ('A3333', 'Finding Inner Peace', 'Blissford', 'Serenity', null);
INSERT INTO books VALUES ('A4444', 'Great Mystery Stories', 'Whodunit', 'Rodney', 5);
INSERT INTO books VALUES ('A5555', 'Software Wizardry', 'Abugov', 'D.', 10);
INSERT INTO patrons VALUES (patron_id_seq.nextval,
'Smith', 'Jane', '123 Main Street', 'Mytown, MA 01234', null);
INSERT INTO patrons VALUES (patron_id_seq.nextval,
'Chen', 'William', '16 S. Maple Road', 'Mytown, MA 01234', null);
INSERT INTO patrons VALUES (patron_id_seq.nextval,
'Fernandez', 'Maria', '502 Harrison Blvd.', 'Sometown, NH 03078', null);
INSERT INTO patrons VALUES (patron_id_seq.nextval,
'Murphy', 'Sam', '57 Main Street', 'Mytown, MA 01234', null);
INSERT INTO transactions (patron_id, book_id,
transaction_date, transaction_type)
VALUES (100, 'A1111', SYSDATE, 1);
INSERT INTO transactions (patron_id, book_id,
transaction_date, transaction_type)
VALUES (100, 'A2222', SYSDATE, 2);
INSERT INTO transactions (patron_id, book_id,
transaction_date, transaction_type)
VALUES (101, 'A3333', SYSDATE, 3);
INSERT INTO transactions (patron_id, book_id,
transaction_date, transaction_type)
VALUES (101, 'A2222', SYSDATE, 1);
INSERT INTO transactions (patron_id, book_id,
transaction_date, transaction_type)
VALUES (102, 'A3333', SYSDATE, 1);
INSERT INTO transactions (patron_id, book_id,
transaction_date, transaction_type)
VALUES (103, 'A4444', SYSDATE, 2);
INSERT INTO transactions (patron_id, book_id,
transaction_date, transaction_type)
VALUES (100, 'A4444', SYSDATE, 1);
INSERT INTO transactions (patron_id, book_id,
transaction_date, transaction_type)
VALUES (102, 'A2222', SYSDATE, 2);
INSERT INTO transactions (patron_id, book_id,
transaction_date, transaction_type)
VALUES (102, 'A5555', SYSDATE, 1);
INSERT INTO transactions (patron_id, book_id,
transaction_date, transaction_type)
VALUES (101, 'A2222', SYSDATE, 1);
Click the Run Script icon, or press the F5 key.
To create a view, go to
Section 4.6, "Create a View".
4.6 Create a View
Create a view that returns information about patrons and their
transactions. This view queries the PATRONS and TRANSACTIONS tables, and
returns rows that contain a patron's ID, last name, and first name,
along with a transaction and the transaction type. The rows are ordered
by patron ID, and by transaction type within patron IDs.
To create the patrons_trans_view view, if you are not already
connected, connect to the database as the user for the schema you are
using for this tutorial. Right-click the Views node in the schema
hierarchy on the left side, select
New View, and enter the following information. (If a tab or field is not mentioned, do not enter anything for it.)
Schema: Specify your current schema as the schema in which to create the view.
Name: patrons_trans_view
In the SQL Query box, enter (or copy and paste) the following statement:
SELECT p.patron_id,
p.last_name,
p.first_name,
t.transaction_type,
t.transaction_date
FROM patrons p, transactions t
WHERE p.patron_id = t.patron_id
ORDER BY p.patron_id, t.transaction_type
Then click
Test Syntax, and ensure that you have not made any syntax errors. If you made any errors, correct then and click Test Syntax again.
Review the SQL statement that SQL Developer will use to create the
view. If you want to make any changes, go back to the SQL Query tab and
make the changes there.
If you want to save the CREATE VIEW statement to a SQL script file, click
Save and specify the location and file name.
When you are finished, click
OK.
You have finished creating the view. If you inserted data to the underlying tables, as described in
Section 4.5, "Insert Data into the Tables",
you can see the data returned by this view as follows: in the
Connections navigator, expand Views, and select PATRONS_TRANS_VIEW, then
click the Data tab.
To create a procedure that lists all books with a specified rating, go to
Section 4.7, "Create a PL/SQL Procedure".
4.7 Create a PL/SQL Procedure
Create a procedure that lists all books with a specified rating. You
can then call this procedure with an input parameter (a number from 1 to
10), and the output will be all the titles of all books with that
rating.
To create the procedure, if you are not already connected, connect to
the database as the user for the schema you are using for this
tutorial. Right-click the Procedures node in the schema hierarchy on the
left side, select
New Procedure, and enter the following information using the Create PL/SQL Procedure dialog box.
Object Name: list_a_rating
Click
OK. A source window for the new
procedure is opened. Enter (or copy and paste) the following procedure
text, replacing any existing text:
CREATE OR REPLACE
PROCEDURE list_a_rating(in_rating IN NUMBER) AS
matching_title VARCHAR2(50);
TYPE my_cursor IS REF CURSOR;
the_cursor my_cursor;
BEGIN
OPEN the_cursor
FOR 'SELECT title
FROM books
WHERE rating = :in_rating'
USING in_rating;
DBMS_OUTPUT.PUT_LINE('All books with a rating of ' || in_rating || ':');
LOOP
FETCH the_cursor INTO matching_title;
EXIT WHEN the_cursor%NOTFOUND;
DBMS_OUTPUT.PUT_LINE(matching_title);
END LOOP;
CLOSE the_cursor;
END list_a_rating;
This procedure uses a cursor (named the_cursor) to return only rows
where the book has the specified rating (in_rating parameter), and uses a
loop to output the title of each book with that rating.
Click the Save icon to save the procedure.
As a usage example, after creating the procedure named LIST_A_RATING,
if you have inserted data into the BOOKS table (for example, using the
INSERT statements in
Section 4.5, "Insert Data into the Tables"), you could use the following statement to return all books with a rating of 10:
CALL list_a_rating(10);
To run this procedure within SQL Developer, right-click LIST_A_RATING in the Connections navigator hierarchy display and select
Run. Under
PL/SQL Block in the Run PL/SQL dialog box, change IN_RATING => IN_RATING to IN_RATING =>
10, and click
OK. The Log window display will now include the following output:
All books with a rating of 10:
Moby Dick
Software Wizardry
4.8 Debug a PL/SQL Procedure
If you want to practice debugging a PL/SQL procedure with SQL
Developer, create a procedure that is like the list_a_rating procedure
that you created in
Section 4.7, "Create a PL/SQL Procedure", but with a logic error. (The coding is also deliberately inefficient, to allow the display of the rating in a variable.)
Before you can debug the procedure, you must ensure that the user
associated with the database connection has the DEBUG CONNECT SESSION
and DEBUG ANY PROCEDURE privileges.
To create this procedure, if you are not already connected, connect
to the database as the user for the schema you are using for this
tutorial. Right-click the Procedures node in the schema hierarchy on the
left side, select
New Procedure, and enter the following information using the Create PL/SQL Procedure dialog box.
Object Name: list_a_rating2
Click
OK. A source window for the new
procedure is opened. Enter (or copy and paste) the following procedure
text, replacing any existing text:
CREATE OR REPLACE
PROCEDURE list_a_rating2(in_rating IN NUMBER) AS
matching_title VARCHAR2(50);
matching_rating NUMBER;
TYPE my_cursor IS REF CURSOR;
the_cursor my_cursor;
rating_cursor my_cursor;
BEGIN
OPEN the_cursor
FOR 'SELECT title
FROM books
WHERE rating <= :in_rating'
USING in_rating;
OPEN rating_cursor FOR 'SELECT rating FROM books WHERE
rating <= :in_rating' USING in_rating;
DBMS_OUTPUT.PUT_LINE('All books with a rating of ' || in_rating || ':');
LOOP
FETCH the_cursor INTO matching_title;
FETCH rating_cursor INTO matching_rating;
EXIT WHEN the_cursor%NOTFOUND;
DBMS_OUTPUT.PUT_LINE(matching_title);
END LOOP;
CLOSE the_cursor;
CLOSE rating_cursor;
END list_a_rating2;
This procedure contains a logic error in the definition of
the_cursor: it selects titles where the rating is less than or equal to a
specified rating, whereas it should select titles only where the rating
is equal to the specified rating.
Click the Save icon to save the procedure.
Assume that you wanted to run this procedure and list all books with a
rating of 10. Right-click LIST_A_RATING2 in the Connections navigator
hierarchy display and select
Run. Under
PL/SQL Block in the Run PL/SQL dialog box, change, change IN_RATING => IN_RATING to IN_RATING =>
10, and click
OK.
In the Log window, however, you see unexpected output: many titles are
listed, including some with ratings other than 10. So, you decide to
debug the procedure.
To debug the procedure, follow these steps:
-
Click the Compile for Debug icon in the toolbar under the LIST_A_RATING2 tab.
-
Set two breakpoints by clicking in the left margin (left of the thin vertical line) beside each of these two lines:
FETCH the_cursor INTO matching_title;
FETCH rating_cursor INTO matching_rating;
Clicking in the left margin toggles the setting and unsetting of
breakpoints. Clicking beside these two lines will enable you to see the
values of the matching_title and matching_rating variables as execution
proceeds in debug mode.
-
Click the Debug icon, and in the Run PL/SQL dialog box change IN_RATING => IN_RATING to IN_RATING => 10; then click OK
-
Click View, then Debugger, then Data to display the Data pane. (Tip: Expand the Name column width so that you can see MATCHING_RATING.)
-
Press the F9 key (or click Debug, then Resume) to have execution proceed, stopping at the next breakpoint.
-
Repeatedly press the F9 key (or click Debug, then Resume),
noticing especially the value of MATCHING_RATING as each row is
processed. You will notice the first incorrect result when you see that
the title Get Rich Really Fast is included,
even though its rating is only 1 (obviously less than 10). (See the
screen illustration with debugging information in Section 1.6, "Running and Debugging Functions and Procedures".)
-
When you have enough information to fix the problem, you can click the Terminate icon in the debugging toolbar.
From this debugging session, you know that to fix the logic error, you should change
rating <= :in_rating
to
rating = :in_rating
in the definition of the_cursor.
4.9 Use the SQL Worksheet for Queries
You can use the SQL Worksheet to test SQL statements using a database connection. To display the worksheet, from the
Tools menu, select
SQL Worksheet.
In the Select Connection dialog box, select the database connection
that you used to create the BOOKS, PATRONS, and TRANSACTIONS tables for
the tutorial in
Chapter 4, "SQL Developer Tutorial: Creating Objects for a Small Database".
The SQL Worksheet has the user interface shown in
Section 1.7, "Using the SQL Worksheet".
In the
Enter SQL Statement box, enter the following statement (the semicolon is optional for the SQL Worksheet):
SELECT author_last_name, title FROM books;
Notice the automatic highlighting of SQL keywords (SELECT and FROM in this example).
Click the Execute SQL Statement icon in the SQL Worksheet toolbar. The results of the query are displayed on the
Results tab under the area in which you entered the SQL statement.
In the
Enter SQL Statement box, enter (or copy and paste) the following statement, which is the same as the SELECT statement in the view you created in
Create a View:
SELECT p.patron_id,
p.last_name,
p.first_name,
t.transaction_type,
t.transaction_date
FROM patrons p, transactions t
WHERE p.patron_id = t.patron_id
ORDER BY p.patron_id, t.transaction_type;
Click the Execute SQL Statement icon in the SQL Worksheet toolbar, and view the results of the query.
Click the Execute Explain Plan icon in the SQL Worksheet toolbar to
see the execution plan (displayed on the Explain tab) that Oracle
Database follows to execute the SQL statement. The information includes
the optimizer strategy and the cost of executing the statement. (For
information about how to generate and interpret execution plans, see
Oracle Database Performance Tuning Guide.)
4.10 Script for Creating and Using the Library Tutorial Objects
The following statements create and use the database objects that you have created (or will create) for the tutorial in
Chapter 4, "SQL Developer Tutorial: Creating Objects for a Small Database". You can view these commands to help you understand the library database objects that are covered in the tutorial.
-- Clean up from any previous tutorial actions.
DROP TABLE transactions;
DROP TABLE books;
DROP TABLE patrons;
DROP SEQUENCE patron_id_seq;
DROP SEQUENCE transactions_seq;
DROP TRIGGER transactions_trg;
DROP VIEW patrons_trans_view;
DROP PROCEDURE list_a_rating;
DROP PROCEDURE list_a_rating2;
set serveroutput on
-- Create objects.
CREATE TABLE books (
book_id VARCHAR2(20),
title VARCHAR2(50)
CONSTRAINT title_not_null NOT NULL,
author_last_name VARCHAR2(30)
CONSTRAINT last_name_not_null NOT NULL,
author_first_name VARCHAR2(30),
rating NUMBER,
CONSTRAINT books_pk PRIMARY KEY (book_id),
CONSTRAINT rating_1_to_10 CHECK (rating IS NULL OR
(rating >= 1 and rating <= 10)),
CONSTRAINT author_title_unique UNIQUE (author_last_name, title));
CREATE TABLE patrons (
patron_id NUMBER,
last_name VARCHAR2(30)
CONSTRAINT patron_last_not_null NOT NULL,
first_name VARCHAR2(30),
street_address VARCHAR2(50),
city_state_zip VARCHAR2(50),
location MDSYS.SDO_GEOMETRY,
CONSTRAINT patrons_pk PRIMARY KEY (patron_id));
CREATE TABLE transactions (
transaction_id NUMBER,
patron_id CONSTRAINT for_key_patron_id
REFERENCES patrons(patron_id),
book_id CONSTRAINT for_key_book_id
REFERENCES books(book_id),
transaction_date DATE
CONSTRAINT tran_date_not_null NOT NULL,
transaction_type NUMBER
CONSTRAINT tran_type_not_null NOT NULL,
CONSTRAINT transactions_pk PRIMARY KEY (transaction_id));
CREATE SEQUENCE patron_id_seq
START WITH 100
INCREMENT BY 1;
-- The sequence for the transaction_id
-- in the tutorial is created automatically,
-- and may have the name TRANSACTIONS_SEQ.
CREATE SEQUENCE transactions_seq
START WITH 1
INCREMENT BY 1;
-- The before-insert trigger for transaction ID values
-- in the tutorial is created automatically,
-- and may have the name TRANSACTIONS_TRG.
CREATE OR REPLACE TRIGGER transactions_trg
BEFORE INSERT ON TRANSACTIONS
FOR EACH ROW
BEGIN
SELECT TRANSACTIONS_SEQ.NEXTVAL INTO :NEW.TRANSACTION_ID FROM DUAL;
END;
/
CREATE VIEW patrons_trans_view AS
SELECT p.patron_id,
p.last_name,
p.first_name,
t.transaction_type,
t.transaction_date
FROM patrons p, transactions t
WHERE p.patron_id = t.patron_id
ORDER BY p.patron_id, t.transaction_type;
-- Procedure: List all books that have a specified rating.
CREATE OR REPLACE PROCEDURE list_a_rating(in_rating IN NUMBER) AS
matching_title VARCHAR2(50);
TYPE my_cursor IS REF CURSOR;
the_cursor my_cursor;
BEGIN
OPEN the_cursor
FOR 'SELECT title
FROM books
WHERE rating = :in_rating'
USING in_rating;
DBMS_OUTPUT.PUT_LINE('All books with a rating of ' || in_rating || ':');
LOOP
FETCH the_cursor INTO matching_title;
EXIT WHEN the_cursor%NOTFOUND;
DBMS_OUTPUT.PUT_LINE(matching_title);
END LOOP;
CLOSE the_cursor;
END;
/
show errors;
-- Insert and query data.
INSERT INTO books VALUES ('A1111', 'Moby Dick', 'Melville', 'Herman', 10);
INSERT INTO books VALUES ('A2222', 'Get Rich Really Fast', 'Scammer', 'Ima', 1);
INSERT INTO books VALUES ('A3333', 'Finding Inner Peace', 'Blissford', 'Serenity', null);
INSERT INTO books VALUES ('A4444', 'Great Mystery Stories', 'Whodunit', 'Rodney', 5);
INSERT INTO books VALUES ('A5555', 'Software Wizardry', 'Abugov', 'D.', 10);
INSERT INTO patrons VALUES (patron_id_seq.nextval,
'Smith', 'Jane', '123 Main Street', 'Mytown, MA 01234', null);
INSERT INTO patrons VALUES (patron_id_seq.nextval,
'Chen', 'William', '16 S. Maple Road', 'Mytown, MA 01234', null);
INSERT INTO patrons VALUES (patron_id_seq.nextval,
'Fernandez', 'Maria', '502 Harrison Blvd.', 'Sometown, NH 03078', null);
INSERT INTO patrons VALUES (patron_id_seq.nextval,
'Murphy', 'Sam', '57 Main Street', 'Mytown, MA 01234', null);
INSERT INTO transactions (patron_id, book_id,
transaction_date, transaction_type)
VALUES (100, 'A1111', SYSDATE, 1);
INSERT INTO transactions (patron_id, book_id,
transaction_date, transaction_type)
VALUES (100, 'A2222', SYSDATE, 2);
INSERT INTO transactions (patron_id, book_id,
transaction_date, transaction_type)
VALUES (101, 'A3333', SYSDATE, 3);
INSERT INTO transactions (patron_id, book_id,
transaction_date, transaction_type)
VALUES (101, 'A2222', SYSDATE, 1);
INSERT INTO transactions (patron_id, book_id,
transaction_date, transaction_type)
VALUES (102, 'A3333', SYSDATE, 1);
INSERT INTO transactions (patron_id, book_id,
transaction_date, transaction_type)
VALUES (103, 'A4444', SYSDATE, 2);
INSERT INTO transactions (patron_id, book_id,
transaction_date, transaction_type)
VALUES (100, 'A4444', SYSDATE, 1);
INSERT INTO transactions (patron_id, book_id,
transaction_date, transaction_type)
VALUES (102, 'A2222', SYSDATE, 2);
INSERT INTO transactions (patron_id, book_id,
transaction_date, transaction_type)
VALUES (102, 'A5555', SYSDATE, 1);
INSERT INTO transactions (patron_id, book_id,
transaction_date, transaction_type)
VALUES (101, 'A2222', SYSDATE, 1);
-- Test the view and the procedure.
SELECT * FROM patrons_trans_view;
CALL list_a_rating(10);