
- •Contents
- •Send Us Your Comments
- •Preface
- •Audience
- •Organization
- •Related Documentation
- •Conventions
- •Documentation Accessibility
- •What's New in Application Development?
- •New Application Development Features in Oracle9i Release 2
- •New Application Development Features in Oracle9i Release 1
- •1 Programmatic Environments
- •Overview of Developing an Oracle Database Application
- •Overview of PL/SQL
- •A Simple PL/SQL Example
- •Advantages of PL/SQL
- •Full Support for SQL
- •Tight Integration with Oracle Database
- •Better Performance
- •Higher Productivity
- •Scalability
- •Maintainability
- •PL/SQL Support for Object-Oriented Programming
- •Object Types
- •Collections
- •Portability
- •Security
- •Built-In Packages for Application Development
- •Built-In Packages for Server Management
- •Built-In Packages for Distributed Database Access
- •Overview of Java Support Built Into the Database
- •Overview of Oracle Extensions to JDBC
- •JDBC Thin Driver
- •JDBC OCI Driver
- •JDBC Server-Side Internal Driver
- •Oracle Database Extensions to JDBC Standards
- •Sample JDBC 2.0 Program
- •Sample Pre-2.0 JDBC Program
- •JDBC in SQLJ Applications
- •Overview of Oracle SQLJ
- •Benefits of SQLJ
- •Comparing SQLJ with JDBC
- •SQLJ Stored Procedures in the Server
- •Overview of Oracle JPublisher
- •Overview of Java Stored Procedures
- •Overview of Database Web Services
- •Database as a Web Service Provider
- •Database as a Web Service Consumer
- •Overview of Writing Procedures and Functions in Java
- •Overview of Writing Database Triggers in Java
- •Why Use Java for Stored Procedures and Triggers?
- •Overview of Pro*C/C++
- •How You Implement a Pro*C/C++ Application
- •Highlights of Pro*C/C++ Features
- •Overview of Pro*COBOL
- •How You Implement a Pro*COBOL Application
- •Highlights of Pro*COBOL Features
- •Overview of OCI and OCCI
- •Advantages of OCI
- •Parts of the OCI
- •Procedural and Non-Procedural Elements
- •Building an OCI Application
- •Overview of Oracle Data Provider for .NET (ODP.NET)
- •Using ODP.NET in a Simple Application
- •Overview of Oracle Objects for OLE (OO4O)
- •OO4O Automation Server
- •OO4O Object Model
- •OraSession
- •OraServer
- •OraDatabase
- •OraDynaset
- •OraField
- •OraMetaData and OraMDAttribute
- •OraParameters and OraParameter
- •OraParamArray
- •OraSQLStmt
- •OraAQ
- •OraAQMsg
- •OraAQAgent
- •Support for Oracle LOB and Object Datatypes
- •OraBLOB and OraCLOB
- •OraBFILE
- •Oracle Data Control
- •Oracle Objects for OLE C++ Class Library
- •Additional Sources of Information
- •Choosing a Programming Environment
- •Choosing Whether to Use OCI or a Precompiler
- •Using Built-In Packages and Libraries
- •Java Compared to PL/SQL
- •PL/SQL Is Optimized for Database Access
- •PL/SQL Is Integrated with the Database
- •Both Java and PL/SQL Have Object-Oriented Features
- •Java Is Used for Open Distributed Applications
- •2 Selecting a Datatype
- •Summary of Oracle Built-In Datatypes
- •Representing Character Data
- •Column Lengths for Single-Byte and Multibyte Character Sets
- •Implicit Conversion Between CHAR/VARCHAR2 and NCHAR/NVARCHAR2
- •Comparison Semantics
- •Representing Numeric Data with Number and Floating-Point Datatypes
- •Floating-Point Number System Concepts
- •About Floating-Point Formats
- •Representing Special Values with Native Floating-Point Formats
- •Behavior of Special Values for Native Floating-Point Datatypes
- •Rounding of Native Floating-Point Datatypes
- •Comparison Operators for Native Floating-Point Datatypes
- •Arithmetic Operators for Native Floating-Point Datatypes
- •Conversion Functions for Native Floating-Point Datatypes
- •Exceptions for Native Floating-Point Datatypes
- •Client Interfaces for Native Floating-Point Datatypes
- •SQL Native Floating-Point Datatypes
- •OCI Native Floating-Point Datatypes SQLT_BFLOAT and SQLT_BDOUBLE
- •Native Floating-Point Datatypes Supported in Oracle OBJECT Types
- •Pro*C/C++ Support for Native Floating-Point Datatypes
- •Storing Data Using the NUMBER Datatype
- •Representing Date and Time Data
- •Date Format
- •Checking If Two DATE Values Refer to the Same Day
- •Displaying the Current Date and Time
- •Setting SYSDATE to a Constant Value
- •Printing a Date with BC/AD Notation
- •Time Format
- •Performing Date Arithmetic
- •Converting Between Datetime Types
- •Handling Time Zones
- •Importing and Exporting Datetime Types
- •Establishing Year 2000 Compliance
- •Oracle Server Year 2000 Compliance
- •Centuries and the Year 2000
- •Examples of The RR Date Format
- •Examples of The CC Date Format
- •Storing Dates in Character Datatypes
- •Viewing Date Settings
- •Altering Date Settings
- •Troubleshooting Y2K Problems in Applications
- •Representing Conditional Expressions as Data
- •Representing Geographic Coordinate Data
- •Representing Image, Audio, and Video Data
- •Representing Searchable Text Data
- •Representing Large Amounts of Data
- •Using RAW and LONG RAW Datatypes
- •Addressing Rows Directly with the ROWID Datatype
- •Extended ROWID Format
- •Different Forms of the ROWID
- •ROWID Pseudocolumn
- •Internal ROWID
- •External Character ROWID
- •External Binary ROWID
- •ROWID Migration and Compatibility Issues
- •Accessing Oracle Database Version 7 from an Oracle9i Client
- •Accessing an Oracle9i Database from a Client of Oracle Database Version 7
- •Import and Export
- •ANSI/ISO, DB2, and SQL/DS Datatypes
- •How Oracle Database Converts Datatypes
- •Datatype Conversion During Assignments
- •Datatype Conversion During Expression Evaluation
- •Representing Dynamically Typed Data
- •Representing XML Data
- •3 Maintaining Data Integrity Through Constraints
- •Overview of Integrity Constraints
- •When to Enforce Business Rules with Integrity Constraints
- •Example of an Integrity Constraint for a Business Rule
- •When to Enforce Business Rules in Applications
- •Creating Indexes for Use with Constraints
- •When to Use NOT NULL Integrity Constraints
- •When to Use Default Column Values
- •Setting Default Column Values
- •Choosing a Table's Primary Key
- •When to Use UNIQUE Key Integrity Constraints
- •Constraints On Views: for Performance, Not Data Integrity
- •Enforcing Referential Integrity with Constraints
- •About Nulls and Foreign Keys
- •Defining Relationships Between Parent and Child Tables
- •No Constraints on the Foreign Key
- •NOT NULL Constraint on the Foreign Key
- •UNIQUE Constraint on the Foreign Key
- •UNIQUE and NOT NULL Constraints on the Foreign Key
- •Rules for Multiple FOREIGN KEY Constraints
- •Deferring Constraint Checks
- •Guidelines for Deferring Constraint Checks
- •Select Appropriate Data
- •Ensure Constraints Are Created Deferrable
- •Set All Constraints Deferred
- •Check the Commit (Optional)
- •Managing Constraints That Have Associated Indexes
- •Minimizing Space and Time Overhead for Indexes Associated with Constraints
- •Guidelines for Indexing Foreign Keys
- •About Referential Integrity in a Distributed Database
- •When to Use CHECK Integrity Constraints
- •Restrictions on CHECK Constraints
- •Designing CHECK Constraints
- •Rules for Multiple CHECK Constraints
- •Choosing Between CHECK and NOT NULL Integrity Constraints
- •Examples of Defining Integrity Constraints
- •Example: Defining Integrity Constraints with the CREATE TABLE Command
- •Example: Defining Constraints with the ALTER TABLE Command
- •Privileges Required to Create Constraints
- •Naming Integrity Constraints
- •Enabling and Disabling Integrity Constraints
- •Why Disable Constraints?
- •About Exceptions to Integrity Constraints
- •Enabling Constraints
- •Creating Disabled Constraints
- •Enabling and Disabling Existing Integrity Constraints
- •Enabling Existing Constraints
- •Disabling Existing Constraints
- •Tip: Using the Data Dictionary to Find Constraints
- •Guidelines for Enabling and Disabling Key Integrity Constraints
- •Fixing Constraint Exceptions
- •Altering Integrity Constraints
- •Renaming Integrity Constraints
- •Dropping Integrity Constraints
- •Managing FOREIGN KEY Integrity Constraints
- •Datatypes and Names for Foreign Key Columns
- •Limit on Columns in Composite Foreign Keys
- •Foreign Key References Primary Key by Default
- •Privileges Required to Create FOREIGN KEY Integrity Constraints
- •Choosing How Foreign Keys Enforce Referential Integrity
- •Viewing Definitions of Integrity Constraints
- •Examples of Defining Integrity Constraints
- •Example 1: Listing All of Your Accessible Constraints
- •Example 2: Distinguishing NOT NULL Constraints from CHECK Constraints
- •Example 3: Listing Column Names that Constitute an Integrity Constraint
- •4 Selecting an Index Strategy
- •Guidelines for Application-Specific Indexes
- •Create Indexes After Inserting Table Data
- •Switch Your Temporary Tablespace to Avoid Space Problems Creating Indexes
- •Index the Correct Tables and Columns
- •Limit the Number of Indexes for Each Table
- •Choose the Order of Columns in Composite Indexes
- •Gather Statistics to Make Index Usage More Accurate
- •Drop Indexes That Are No Longer Required
- •Privileges Required to Create an Index
- •Creating Indexes: Basic Examples
- •When to Use Domain Indexes
- •When to Use Function-Based Indexes
- •Advantages of Function-Based Indexes
- •Examples of Function-Based Indexes
- •Example: Function-Based Index for Case-Insensitive Searches
- •Example: Precomputing Arithmetic Expressions with a Function-Based Index
- •Example: Function-Based Index for Language-Dependent Sorting
- •Restrictions for Function-Based Indexes
- •5 How Oracle Database Processes SQL Statements
- •Overview of SQL Statement Execution
- •Identifying Extensions to SQL92 (FIPS Flagging)
- •Grouping Operations into Transactions
- •Improving Transaction Performance
- •Committing Transactions
- •Rolling Back Transactions
- •Defining Transaction Savepoints
- •An Example of COMMIT, SAVEPOINT, and ROLLBACK
- •Privileges Required for Transaction Management
- •Ensuring Repeatable Reads with Read-Only Transactions
- •Using Cursors within Applications
- •Declaring and Opening Cursors
- •Using a Cursor to Execute Statements Again
- •Closing Cursors
- •Cancelling Cursors
- •Locking Data Explicitly
- •Choosing a Locking Strategy
- •When to Lock with ROW SHARE and ROW EXCLUSIVE Mode
- •When to Lock with SHARE Mode
- •When to Lock with SHARE ROW EXCLUSIVE Mode
- •When to Lock in EXCLUSIVE Mode
- •Privileges Required
- •Letting Oracle Database Control Table Locking
- •Explicitly Acquiring Row Locks
- •About User Locks
- •When to Use User Locks
- •Example of a User Lock
- •Viewing and Monitoring Locks
- •Using Serializable Transactions for Concurrency Control
- •How Serializable Transactions Interact
- •Setting the Isolation Level of a Transaction
- •The INITRANS Parameter
- •Referential Integrity and Serializable Transactions
- •Using SELECT FOR UPDATE
- •READ COMMITTED and SERIALIZABLE Isolation
- •Transaction Set Consistency
- •Comparison of READ COMMITTED and SERIALIZABLE Transactions
- •Choosing an Isolation Level for Transactions
- •Application Tips for Transactions
- •Autonomous Transactions
- •Examples of Autonomous Transactions
- •Entering a Buy Order
- •Example: Making a Bank Withdrawal
- •Defining Autonomous Transactions
- •Restrictions on Autonomous Transactions
- •Resuming Execution After a Storage Error Condition
- •What Operations Can Be Resumed After an Error Condition?
- •Limitations on Resuming Operations After an Error Condition
- •Writing an Application to Handle Suspended Storage Allocation
- •Example of Resumable Storage Allocation
- •6 Coding Dynamic SQL Statements
- •What Is Dynamic SQL?
- •Why Use Dynamic SQL?
- •Executing DDL and SCL Statements in PL/SQL
- •Executing Dynamic Queries
- •Referencing Database Objects that Do Not Exist at Compilation
- •Optimizing Execution Dynamically
- •Executing Dynamic PL/SQL Blocks
- •Performing Dynamic Operations Using Invoker's Rights
- •A Dynamic SQL Scenario Using Native Dynamic SQL
- •Sample DML Operation Using Native Dynamic SQL
- •Sample DDL Operation Using Native Dynamic SQL
- •Sample Single-Row Query Using Native Dynamic SQL
- •Sample Multiple-Row Query Using Native Dynamic SQL
- •Choosing Between Native Dynamic SQL and the DBMS_SQL Package
- •Advantages of Native Dynamic SQL
- •Native Dynamic SQL is Easy to Use
- •Native Dynamic SQL is Faster than DBMS_SQL
- •Performance Tip: Using Bind Variables
- •Native Dynamic SQL Supports User-Defined Types
- •Native Dynamic SQL Supports Fetching Into Records
- •Advantages of the DBMS_SQL Package
- •DBMS_SQL is Supported in Client-Side Programs
- •DBMS_SQL Supports DESCRIBE
- •DBMS_SQL Supports SQL Statements Larger than 32KB
- •DBMS_SQL Lets You Reuse SQL Statements
- •Examples of DBMS_SQL Package Code and Native Dynamic SQL Code
- •Querying Using Dynamic SQL: Example
- •Performing DML Using Dynamic SQL: Example
- •Performing DML with RETURNING Clause Using Dynamic SQL: Example
- •Using Dynamic SQL in Languages Other Than PL/SQL
- •7 Using Procedures and Packages
- •Overview of PL/SQL Program Units
- •Anonymous Blocks
- •Stored Program Units (Procedures, Functions, and Packages)
- •Naming Procedures and Functions
- •Parameters for Procedures and Functions
- •Parameter Modes
- •Parameter Datatypes
- •%TYPE and %ROWTYPE Attributes
- •Tables and Records
- •Default Parameter Values
- •Creating Stored Procedures and Functions
- •Privileges to Create Procedures and Functions
- •Altering Stored Procedures and Functions
- •Dropping Procedures and Functions
- •Privileges to Drop Procedures and Functions
- •External Procedures
- •PL/SQL Packages
- •Example of a PL/SQL Package Specification and Body
- •PL/SQL Object Size Limitation
- •Size Limitation by Version
- •Creating Packages
- •Creating Packaged Objects
- •Privileges to Create or Drop Packages
- •Naming Packages and Package Objects
- •Package Invalidations and Session State
- •Packages Supplied With Oracle Database
- •Overview of Bulk Binds
- •When to Use Bulk Binds
- •DML Statements that Reference Collections
- •SELECT Statements that Reference Collections
- •FOR Loops that Reference Collections and the Returning Into Clause
- •Triggers
- •Hiding PL/SQL Code with the PL/SQL Wrapper
- •Compiling PL/SQL Procedures for Native Execution
- •Remote Dependencies
- •Timestamps
- •Disadvantages of the Timestamp Model
- •Signatures
- •When Does a Signature Change?
- •Modes
- •Default Parameter Values
- •Examples of Changing Procedure Signatures
- •Controlling Remote Dependencies
- •Dependency Resolution
- •Suggestions for Managing Dependencies
- •Cursor Variables
- •Declaring and Opening Cursor Variables
- •Examples of Cursor Variables
- •Fetching Data
- •Implementing Variant Records
- •Handling PL/SQL Compile-Time Errors
- •Handling Run-Time PL/SQL Errors
- •Declaring Exceptions and Exception Handling Routines
- •Unhandled Exceptions
- •Handling Errors in Distributed Queries
- •Handling Errors in Remote Procedures
- •Debugging Stored Procedures
- •Calling Stored Procedures
- •A Procedure or Trigger Calling Another Procedure
- •Interactively Calling Procedures From Oracle Database Tools
- •Calling Procedures within 3GL Applications
- •Name Resolution When Calling Procedures
- •Privileges Required to Execute a Procedure
- •Specifying Values for Procedure Arguments
- •Calling Remote Procedures
- •Remote Procedure Calls and Parameter Values
- •Referencing Remote Objects
- •Synonyms for Procedures and Packages
- •Calling Stored Functions from SQL Expressions
- •Using PL/SQL Functions
- •Syntax for SQL Calling a PL/SQL Function
- •Naming Conventions
- •Name Precedence
- •Example of Calling a PL/SQL Function from SQL
- •Arguments
- •Using Default Values
- •Privileges
- •Requirements for Calling PL/SQL Functions from SQL Expressions
- •Controlling Side Effects
- •Restrictions
- •Declaring a Function
- •Parallel Query and Parallel DML
- •PRAGMA RESTRICT_REFERENCES – for Backward Compatibility
- •Using the Keyword TRUST
- •Differences between Static and Dynamic SQL Statements.
- •Overloading Packaged PL/SQL Functions
- •Serially Reusable PL/SQL Packages
- •Package States
- •Why Serially Reusable Packages?
- •Syntax of Serially Reusable Packages
- •Semantics of Serially Reusable Packages
- •Examples of Serially Reusable Packages
- •Example 1: How Package Variables Act Across Call Boundaries
- •Example 2: How Package Variables Act Across Call Boundaries
- •Example 3: Open Cursors in Serially Reusable Packages at Call Boundaries
- •Returning Large Amounts of Data from a Function
- •Coding Your Own Aggregate Functions
- •8 Calling External Procedures
- •Overview of Multi-Language Programs
- •What Is an External Procedure?
- •Overview of The Call Specification for External Procedures
- •Loading External Procedures
- •Loading Java Class Methods
- •Loading External C Procedures
- •Publishing External Procedures
- •The AS LANGUAGE Clause for Java Class Methods
- •The AS LANGUAGE Clause for External C Procedures
- •LIBRARY
- •NAME
- •LANGUAGE
- •CALLING STANDARD
- •WITH CONTEXT
- •PARAMETERS
- •AGENT IN
- •Publishing Java Class Methods
- •Publishing External C Procedures
- •Locations of Call Specifications
- •Example: Locating a Call Specification in a PL/SQL Package Body
- •Example: Locating a Call Specification in an Object Type Specification
- •Example: Locating a Call Specification in an Object Type Body
- •Passing Parameters to External C Procedures with Call Specifications
- •Specifying Datatypes
- •External Datatype Mappings
- •BY VALUE/REFERENCE for IN and IN OUT Parameter Modes
- •The PARAMETERS Clause
- •Overriding Default Datatype Mapping
- •Specifying Properties
- •INDICATOR
- •LENGTH and MAXLEN
- •CHARSETID and CHARSETFORM
- •Repositioning Parameters
- •Using SELF
- •Passing Parameters by Reference
- •WITH CONTEXT
- •Inter-Language Parameter Mode Mappings
- •Executing External Procedures with the CALL Statement
- •Preconditions for External Procedures
- •Privileges of External Procedures
- •Managing Permissions
- •Creating Synonyms for External Procedures
- •CALL Statement Syntax
- •Calling Java Class Methods
- •How the Database Server Calls External C Procedures
- •Handling Errors and Exceptions in Multi-Language Programs
- •Generic Compile Time Call specification Errors
- •C Exception Handling
- •Using Service Procedures with External C Procedures
- •OCIExtProcAllocCallMemory
- •OCIExtProcRaiseExcp
- •OCIExtProcRaiseExcpWithMsg
- •Doing Callbacks with External C Procedures
- •OCIExtProcGetEnv
- •Object Support for OCI Callbacks
- •Restrictions on Callbacks
- •Debugging External Procedures
- •Using Package DEBUG_EXTPROC
- •Demo Program
- •Guidelines for External C Procedures
- •Restrictions on External C Procedures
- •9 Using Triggers
- •Designing Triggers
- •Creating Triggers
- •Types of Triggers
- •Overview of System Events
- •Getting the Attributes of System Events
- •Naming Triggers
- •When Is the Trigger Fired?
- •Do Import and SQL*Loader Fire Triggers?
- •How Column Lists Affect UPDATE Triggers
- •Controlling When a Trigger Is Fired (BEFORE and AFTER Options)
- •Ordering of Triggers
- •Modifying Complex Views (INSTEAD OF Triggers)
- •Views that Require INSTEAD OF Triggers
- •INSTEAD OF Trigger Example
- •Object Views and INSTEAD OF Triggers
- •Triggers on Nested Table View Columns
- •Firing Triggers One or Many Times (FOR EACH ROW Option)
- •Firing Triggers Based on Conditions (WHEN Clause)
- •Coding the Trigger Body
- •Example: Monitoring Logons with a Trigger
- •Example: Calling a Java Procedure from a Trigger
- •Accessing Column Values in Row Triggers
- •Example: Modifying LOB Columns with a Trigger
- •INSTEAD OF Triggers on Nested Table View Columns
- •Avoiding Name Conflicts with Triggers (REFERENCING Option)
- •Detecting the DML Operation That Fired a Trigger
- •Error Conditions and Exceptions in the Trigger Body
- •Triggers and Handling Remote Exceptions
- •Restrictions on Creating Triggers
- •Who Is the Trigger User?
- •Privileges Needed to Work with Triggers
- •Compiling Triggers
- •Dependencies for Triggers
- •Recompiling Triggers
- •Modifying Triggers
- •Debugging Triggers
- •Enabling and Disabling Triggers
- •Enabling Triggers
- •Disabling Triggers
- •Viewing Information About Triggers
- •Examples of Trigger Applications
- •Auditing with Triggers: Example
- •Integrity Constraints and Triggers: Examples
- •Referential Integrity Using Triggers
- •Foreign Key Trigger for Child Table
- •UPDATE and DELETE RESTRICT Trigger for Parent Table
- •UPDATE and DELETE SET NULL Triggers for Parent Table: Example
- •DELETE Cascade Trigger for Parent Table: Example
- •UPDATE Cascade Trigger for Parent Table: Example
- •Trigger for Complex Check Constraints: Example
- •Complex Security Authorizations and Triggers: Example
- •Transparent Event Logging and Triggers
- •Derived Column Values and Triggers: Example
- •Building Complex Updatable Views Using Triggers: Example
- •Tracking System Events Using Triggers
- •Fine-Grained Access Control Using Triggers: Example
- •CALL Syntax
- •Responding to System Events through Triggers
- •10 Working With System Events
- •Event Attribute Functions
- •List of Database Events
- •System Events
- •Client Events
- •11 Using the Publish-Subscribe Model for Applications
- •Introduction to Publish-Subscribe
- •Publish-Subscribe Architecture
- •Publish-Subscribe Concepts
- •Examples of a Publish-Subscribe Mechanism
- •12 Using Regular Expressions With Oracle Database
- •What are Regular Expressions?
- •Oracle Database Regular Expression Support
- •Oracle Database SQL Functions for Regular Expressions
- •Metacharacters Supported in Regular Expressions
- •Constructing Regular Expressions
- •Basic String Matching with Regular Expressions
- •Regular Expression Operations on Subexpressions
- •Regular Expression Operator and Metacharacter Usage
- •13 Developing Web Applications with PL/SQL
- •PL/SQL Web Applications
- •PL/SQL Gateway
- •Configuring mod_plsql
- •Uploading and Downloading Files With PL/SQL Gateway
- •Uploading Files to the Database
- •Downloading Files From the Database
- •Custom Authentication With PL/SQL Gateway
- •PL/SQL Web Toolkit
- •Generating HTML Output from PL/SQL
- •Passing Parameters to a PL/SQL Web Application
- •Passing List and Dropdown List Parameters from an HTML Form
- •Passing Radio Button and Checkbox Parameters from an HTML Form
- •Passing Entry Field Parameters from an HTML Form
- •Passing Hidden Parameters from an HTML Form
- •Uploading a File from an HTML Form
- •Submitting a Completed HTML Form
- •Handling Missing Input from an HTML Form
- •Maintaining State Information Between Web Pages
- •Performing Network Operations within PL/SQL Stored Procedures
- •Sending E-Mail from PL/SQL
- •Getting a Host Name or Address from PL/SQL
- •Working with TCP/IP Connections from PL/SQL
- •Retrieving the Contents of an HTTP URL from PL/SQL
- •Working with Tables, Image Maps, Cookies, and CGI Variables from PL/SQL
- •Embedding PL/SQL Code in Web Pages (PL/SQL Server Pages)
- •Choosing a Software Configuration
- •Choosing Between PSP and the PL/SQL Web Toolkit
- •How PSP Relates to Other Scripting Solutions
- •Writing the Code and Content for the PL/SQL Server Page
- •The Format of the PSP File
- •Syntax of PL/SQL Server Page Elements
- •Page Directive
- •Procedure Directive
- •Parameter Directive
- •Include Directive
- •Declaration Block
- •Code Block (Scriptlet)
- •Expression Block
- •Loading the PL/SQL Server Page into the Database as a Stored Procedure
- •Running a PL/SQL Server Page Through a URL
- •Sample PSP URLs
- •Examples of PL/SQL Server Pages
- •Sample Table
- •Dumping the Sample Table
- •Printing the Sample Table using a Loop
- •Allowing a User Selection
- •Sample HTML Form to Call a PL/SQL Server Page
- •Debugging PL/SQL Server Page Problems
- •Putting an Application using PL/SQL Server Pages into Production
- •Enabling PL/SQL Web Applications for XML
- •14 Porting Non-Oracle Applications to Oracle Database 10g
- •Performing Natural Joins and Inner Joins
- •Migrating a Schema and Data from Another Database System
- •Performing Several Comparisons within a Query
- •15 Using Flashback Features
- •Overview of Flashback Features
- •Application Development Features
- •Database Administration Features
- •Database Administration Tasks Before Using Flashback Features
- •Using Flashback Query (SELECT ... AS OF)
- •Examining Past Data: Example
- •Tips for Using Flashback Query
- •Using the DBMS_FLASHBACK Package
- •Using ORA_ROWSCN
- •Using Flashback Version Query
- •Using Flashback Transaction Query
- •Flashback Transaction Query and Flashback Version Query: Example
- •Flashback Tips
- •Flashback Tips – Performance
- •Flashback Tips – General
- •16 Using Oracle XA with Transaction Monitors
- •X/Open Distributed Transaction Processing (DTP)
- •Required Public Information
- •XA and the Two-Phase Commit Protocol
- •Transaction Processing Monitors (TPMs)
- •Support for Dynamic and Static Registration
- •Oracle XA Library Interface Subroutines
- •XA Library Subroutines
- •Extensions to the XA Interface
- •Developing and Installing Applications That Use the XA Libraries
- •Responsibilities of the DBA or System Administrator
- •Responsibilities of the Application Developer
- •Defining the xa_open String
- •Syntax of the xa_open String
- •Required Fields
- •Optional Fields
- •Interfacing XA with Precompilers and OCIs
- •Using Precompilers with the Oracle XA Library
- •Using Precompilers with the Default Database
- •Using Precompilers with a Named Database
- •Using OCI with the Oracle XA Library
- •Transaction Control using XA
- •Examples of Precompiler Applications
- •Migrating Precompiler or OCI Applications to TPM Applications
- •XA Library Thread Safety
- •Specifying Threading in the Open String
- •Restrictions on Threading in XA
- •Troubleshooting XA Applications
- •XA Trace Files
- •The xa_open string DbgFl
- •Trace File Locations
- •Trace File Examples
- •In-Doubt or Pending Transactions
- •Oracle Database SYS Account Tables
- •XA Issues and Restrictions
- •Changes to Oracle XA Support
- •XA Changes from Release 8.0 to Release 8.1
- •XA Changes from Release 7.3 to Release 8.0
- •Session Caching Is No Longer Needed
- •Dynamic Registration Is Supported
- •Loosely Coupled Transaction Branches Are Supported
- •SQLLIB Is Not Needed for OCI Applications
- •No Installation Script Is Needed to Run XA
- •XA Library Use with Oracle Real Application Clusters Option on All Platforms
- •Transaction Recovery for Oracle Real Application Clusters Has Been Improved
- •Both Global and Local Transactions Are Possible
- •The xa_open String Has Been Modified
- •Index
- •Symbols
- •Numerics
Какую работу нужно написать?

Embedding PL/SQL Code in Web Pages (PL/SQL Server Pages)
PSP uses the same script tag syntax as Java Server Pages (JSP), to make it easy to switch back and forth.
PSP uses syntax similar to that of Active Server Pages (ASP), although the syntax is not identical and you must typically translate from VBScript or JScript to PL/SQL. The best candidates for migration are pages that use the Active Data Object (ADO) interface to do database operations.
Writing the Code and Content for the PL/SQL Server Page
You can start with an existing Web page, or with an existing stored procedure. Either way, with a few additions and changes you can create dynamic Web pages that perform database operations and display the results.
The Format of the PSP File
The file for a PL/SQL server page must have the extension .psp.
It can contain whatever content you like, with text and tags interspersed with PSP directives, declarations, and scriptlets:
■In the simplest case, it is nothing more than an HTML file. Compiling it as a PL/SQL server page produces a stored procedure that outputs the exact same HTML file.
■In the most complex case, it is a PL/SQL procedure that generates all the content of the Web page, including the tags for title, body, and headings.
■In the typical case, it is a mix of HTML (providing the static parts of the page) and PL/SQL (filling in the dynamic content).
The order and placement of the PSP directives and declarations is not significant in most cases -- only when another file is being included. For ease of maintenance, we recommend placing the directives and declarations together near the beginning of the file.
The following sections discuss the way to produce various results using the PSP scripting elements. If you are familiar with dynamic HTML and want to start coding right away, you can jump forward to Syntax of PL/SQL Server Page Elements on page 13-27 and "Examples of PL/SQL Server Pages" on page 13-31.
Specifying the Scripting Language
To identify a file as a PL/SQL Server Page, include a
<%@ page language="PL/SQL" %> directive somewhere in the file. This directive is for compatibility with other scripting environments.
Developing Web Applications with PL/SQL 13-21

Embedding PL/SQL Code in Web Pages (PL/SQL Server Pages)
Accepting User Input
User input comes encoded in the URL that retrieves the HTML page. You can generate the URL by hard-coding it in an HTML link, or by calling your page as the "action" of an HTML form. Your page receives the input as parameters to a PL/SQL stored procedure.
To set up parameter passing for a PL/SQL server page, include a
<%@ plsql parameter="varname" %> directive. By default, parameters are of type VARCHAR2. To use a different type, include a type="typename" attribute within the directive. To set a default value, so that the parameter becomes optional, include a default="expression" attribute in the directive. The values for this attribute are substituted directly into a PL/SQL statement, so any strings must be single-quoted, and you can use special values such as null.
Displaying HTML
The PL/SQL parts of the page are enclosed within special delimiters. All other content is passed along verbatim -- including any whitespace -- to the browser. To display text or HTML tags, write it as you would a typical Web page. You do not need to call any output function.
Sometimes you might want to display one line of output or another, or change the value of an attribute, based on some condition. You can include IF/THEN logic and variable substitution inside the PSP delimiters, as shown in subsequent sections.
Returning XML, Text, or Other Document Types
By default, the PL/SQL gateway transmits files as HTML documents, so that the browser formats them according to the HTML tags. If you want the browser to interpret the document as XML, plain text (with no formatting), or some other document type, include a <%@ page contentType="MIMEtype" %> directive. (The attribute name is case-sensitive, so be sure to capitalize it as contentType.) Specify text/html, text/xml, text/plain, image/jpeg, or some other MIME type that the browser or other client program recognizes. Users may have to configure their browsers to recognize some MIME types.
Typically, a PL/SQL server page is intended to be displayed in a Web browser. It could also be retrieved and interpreted by a program that can make HTTP requests, such as a Java or Perl application.
Returning Pages Containing Different Character Sets
By default, the PL/SQL gateway transmits files using the character set defined by the Web gateway. To convert the data to a different character set for displaying in a
13-22 Oracle Database Application Developer's Guide - Fundamentals

Embedding PL/SQL Code in Web Pages (PL/SQL Server Pages)
browser, include a <%@ page charset="encoding" %> directive. Specify Shift_JIS, Big5, UTF-8, or another encoding that the browser or other client program recognizes.
You must also configure the character set setting in the database accessor descriptor (DAD) of the Web gateway. Users may have to select the same encoding in their browsers to see the data displayed properly.
For example, a database in Japan might have a database character set that uses the EUC encoding, while the Web browsers are set up to display Shift_JIS encoding.
Handling Script Errors
Any errors in HTML tagging are handled by the browser. The PSP loading process does not check for them.
If you make a syntax error in the PL/SQL code, the loader stops and you must fix the error before continuing. Note that any previous version of the stored procedure can be erased when you attempt to replace it and the script contains a syntax error. You might want to use one database for prototyping and debugging, then load the final stored procedure into a different database for production. You can switch databases using a command-line flag, without changing any source code.
To handle database errors that occur when the script runs, you can include PL/SQL exception-handling code within a PSP file, and have any unhandled exceptions bring up a special page. The page for unhandled exceptions is another PL/SQL server page with extension .psp. The error procedure does not receive any parameters, so to determine the cause of the error, it can call the SQLCODE and SQLERRM functions.
You can also display a standard HTML page without any scripting when an error occurs, but you must still give it the extension .psp and load it into the database as a stored procedure.
Naming the PL/SQL Stored Procedure in a PSP Script
Each top-level PL/SQL server page corresponds to a stored procedure within the server. By default, the procedure is given the same name as the original file, with the .psp extension removed. To name the procedure something else, include a include a <%@ plsql procedure="procname" %> directive.
Including the Contents of Other Files in a PSP Script
You can set up an include mechanism to pull in the contents of other files, typically containing either static HTML content or more PL/SQL scripting code. Include a
Developing Web Applications with PL/SQL 13-23

Embedding PL/SQL Code in Web Pages (PL/SQL Server Pages)
<%@ include file="filename" %> directive at the point where the other file's content should appear. Because the files are processed at the point where you load the stored procedure into the database, the substitution is done only once, not whenever the page is served.
You can use any names and extensions for the included files. If the included files contain PL/SQL scripting code, they do not need their own set of directives to identify the procedure name, character set, and so on.
When specifying the names of files to the PSP loader, you must include the names of all included files also. Specify the names of included files before the names of any
.psp files.
You can use this feature to pull in the same content, such as a navigation banner, into many different files. Or, you can use it as a macro capability to include the same section of script code in more than one place in a page.
Declaring Variables in a PSP Script
If you need to use global variables within the script, you can include a declaration block inside the delimiters <%! %>. All the usual PL/SQL syntax is allowed within the block. The delimiters server as shorthand, letting you omit the DECLARE keyword. All the declarations are available to the code later on in the file.
You can specify multiple declaration blocks; internally, they are all merged into a single block when the PSP file is made into a stored procedure.
You can also use explicit DECLARE blocks within the <% %> delimiters that are explained later. These declarations are only visible to the following BEGIN/END block.
Specifying Executable Statements in a PSP Script
You can include any PL/SQL statements within the delimiters <% %>. The statements can be complete, or clauses of a compound statement, such as the IF part of an IF-THEN-ELSE statement. Any variables declared within DECLARE blocks are only visible to the following BEGIN/END block.
Substituting an Expression Result in a PSP Script
To include a value that depends upon the result of a PL/SQL expression, include the expression within the delimiters <%= %>. Because the result is always substituted in the middle of text or tags, it must be a string value or be able to be cast to a string. For any types that cannot be implicitly cast, such as DATE, pass the value to the PL/SQL TO_CHAR function.
13-24 Oracle Database Application Developer's Guide - Fundamentals

Embedding PL/SQL Code in Web Pages (PL/SQL Server Pages)
The content between the <%= %> delimiters is processed by the HTP.PRN function, which trims any leading or trailing whitespace and requires that you quote any literal strings.
Conventions for Quoting and Escaping Strings in a PSP Script
When values specified in PSP attributes are used for PL/SQL operations, they are passed exactly as you specify them in the PSP file. If PL/SQL requires a single-quoted string, you must specify the string with the single quotes around it -- and surround the whole thing with double quotes.
You can also nest single-quoted strings inside single quotes. In this case, you must escape the nested single quotes by specifying the sequence \'.
Most characters and character sequences can be included in a PSP file without being changed by the PSP loader. To include the sequence %>, specify the escape sequence %\>. To include the sequence <%, specify the escape sequence <\%.
Including Comments in a PSP Script
To put a comment in the HTML portion of a PL/SQL server page, for the benefit of people reading the PSP source code, use the syntax:
<%-- Comment text --%>
These comments do not appear in the HTML output from the PSP.
To create a comment that is visible in the HTML output, place the comment in the HTML portion and use the regular HTML comment syntax:
<!-- Comment text -->
To include a comment inside a PL/SQL block within a PSP, you can use the normal PL/SQL comment syntax.
For example, here is part of a PSP file showing several kinds of comments:
<p>Today we introduce our new model XP-10. <%--
This is the project with code name "Secret Project". People viewing the HTML page will not see this comment. --%> <!--
Some pictures of the XP-10.
People viewing the HTML page will see this comment. --> <%
Developing Web Applications with PL/SQL 13-25

Embedding PL/SQL Code in Web Pages (PL/SQL Server Pages)
for image_file in (select pathname, width, height, description from image_library where model_num = 'XP-10')
--Comments interspersed with PL/SQL statements.
--People viewing the HTML page will not see this comment. loop
%>
<img src="<%= image_file.pathname %>" width=<% image_file.width %> height=<% image_file.height %> alt="<% image_file.description %>"> <br>
<%
end loop; %>
Retrieving a Result Set from a Query in a PSP Script
If your background is in HTML design, here are a few examples of retrieving data from the database and displaying it.
To display the results of a query that returns multiple rows, you can iterate through each row of the result set, printing the appropriate columns using HTML list or table tags:
<% FOR item IN (SELECT * FROM some_table) LOOP %> <TR>
<TD><%= item.col1 %></TD> <TD><%= item.col2 %></TD> </TR>
<% END LOOP; %>
If you want to print out an entire database table in one operation, you can call the
OWA_UTIL.TABLEPRINT or OWA_UTIL.CELLSPRINT procedures from the PL/SQL Web toolkit:
<% OWA_UTIL.TABLEPRINT(CTABLE => 'some_table', CATTRIBUTES => 'border=2', CCOLUMNS => 'col1, col2', CCLAUSES => 'WHERE col1 > 5'); %>
htp.tableOpen('border=2');
owa_util.cellsprint( 'select col1, col2 from some_table where col1 > 5'); htp.tableClose;
13-26 Oracle Database Application Developer's Guide - Fundamentals