Wrox Professional Oracle Programming Jun 2005 ISBN 0764574825 pdf
Professional Oracle® Programming
Rick Greenwald, Robert Stackowiak, Gary Dodge, David Klein, Ben Shapiro,
Christopher G. Chelliah
Professional Oracle® Programming
Professional Oracle® Programming
Rick Greenwald, Robert Stackowiak, Gary Dodge, David Klein, Ben Shapiro,
Christopher G. Chelliah Copyright © 2005 by Wiley Publishing Inc. All rights reserved. Published by Wiley Publishing, Inc., Indianapolis, Indiana Published simultaneously in Canada
No part of this publication may be reproduced, stored in a retrieval system, or transmitted in any form or by
any means, electronic, mechanical, photocopying, recording, scanning, or otherwise, except as permitted under Section 107 or 108 of the 1976 United States Copyright Act, without either the prior written permis- sion of the Publisher, or authorization through payment of the appropriate per-copy fee to the CopyrightClearance Center, Inc., 222 Rosewood Drive, Danvers, MA 01923, (978) 750-8400, fax (978) 646-8700. Requests
to the Publisher for permission should be addressed to the Legal Department, Wiley Publishing, Inc., 10475
Crosspoint Blvd., Indianapolis, IN 46256, (317) 572-3447, fax (317) 572-4355, or online at http://www.wiley.com/go/permissions .
NO REPRESENTATIONS OR WARRANTIES WITH RESPECT TO THE ACCURACY OR COMPLETENESS
OF THE CONTENTS OF THIS WORK AND SPECIFICALLY DISCLAIM ALL WARRANTIES, INCLUDING
WITHOUT LIMITATION WARRANTIES OF FITNESS FOR A PARTICULAR PURPOSE. NO WARRANTY
MAY BE CREATED OR EXTENDED BY SALES OR PROMOTIONAL MATERIALS. THE ADVICE AND
STRATEGIES CONTAINED HEREIN MAY NOT BE SUITABLE FOR EVERY SITUATION. THIS WORK IS
SOLD WITH THE UNDERSTANDING THAT THE PUBLISHER IS NOT ENGAGED IN RENDERING
LEGAL, ACCOUNTING, OR OTHER PROFESSIONAL SERVICES. IF PROFESSIONAL ASSISTANCE IS
REQUIRED, THE SERVICES OF A COMPETENT PROFESSIONAL PERSON SHOULD BE SOUGHT.
NEITHER THE PUBLISHER NOT THE AUTHOR SHALL BE LIABLE FOR DAMAGES ARISING HERE-
FROM. THE FACT THAT AN ORGANIZATION OR WEBSITE IS REFERRED TO IN THIS WORK AS A
CITATION AND/OR A POTENTIAL SOURCE OF FURTHER INFORMATION DOES NOT MEAN THAT
THE AUTHOR OR THE PUBLISHER ENDORSES THE INFORMATION THE ORGANIZATION OR
WEBSITE MAY PROVIDE OR RECOMMENDATIONS IT MAY MAKE. FURTHER, READERS SHOULD BE
AWARE THAT INTERNET WEBSITES LISTED IN THIS WORK MAY HAVE CHANGED OR DISAP-
For general information on our other products and services please contact our Customer Care Department
within the United States at (800) 762-2974, outside the United States at (317) 572-3993 or fax (317) 572-4002.
Trademarks: Wiley, the Wiley Publishing logo, Wrox, the Wrox logo, and Programmer to Programmer are trademarks or registered trademarks of John Wiley & Sons, Inc. and/or its affiliates. All other trademarks are the property of their respective owners. Wiley Publishing, Inc., is not associated with any product or vendor mentioned in this book.
Wiley also publishes its books in a variety of electronic formats. Some content that appears in print may not
be available in electronic books.Library of Congress Cataloging-in-Publication Data: Professional Oracle programming / Rick Greenwald ... [et al.]. p. cm. Includes indexes.
ISBN-13: 978-0-7645-7482-5 (paper/website)
ISBN-10: 0-7645-7482-5 (paper/website) 1. Oracle (Computer file) 2. Relational databases. I. Greenwald, Rick. QA76.9.D3P76646 2005 005.75'85--dc22
2005010511
ISBN 10: 0-7645-7482-5 Printed in the United States of America 10 9 8 7 6 5 4 3 2 1
1B/QS/QW/QV/IN
About the Authors
Rick Greenwald has been in the technology industry for over 20 years and is the author of 12 previous
books, most of them on Oracle. He has been involved with development and databases for his entire career, including stops at Data General, Cognos, Gupta Technologies, and his current employer, Oracle. Computers and computing are a sideline for Rick — his real job is father to his three wonderful girls, with a primary hobby of music appreciation.
Robert Stackowiak is Senior Director of Business Intelligence (BI) in Oracle’s Technology Business Unit.
He is recognized worldwide for his expertise in business intelligence and data warehousing in leading the North American BI team at Oracle. His background includes over 20 years in IT related roles at Oracle, IBM, Harris Computer Systems, and the U.S. Army Corps of Engineers including management of technical teams, software development, sales and sales consulting, systems engineering, and business development.
Gary Dodge has been focused on database technology since his first COBOL programming job with IMS
DB/DC in 1976. He joined Oracle Corporation in 1987 and has served in various management and technical positions within both the sales and consulting divisions. He has been a frequent speaker on database topics at many local and national information technology conferences. In addition to several magazine articles, he is co-author (with Tim Gorman) of Oracle8 Data Warehousing and Essential Oracle8i
Data Warehousing , both published by John Wiley & Sons.
David Klein has been in the technology industry for over 20 years with a variety of companies, including
Data General, Wang Laboratories, Gupta Technologies, Oracle, and a few consulting services companies.He has had many roles, including management of application development and database design teams, sales and sales consulting, systems engineering and marketing. Recently, he has focused on developing classroom and online training courses. An active wife and two boys and a 200-year-old house take up any free time.
Ben Shapiro is the president of ObjectArts Inc., a New York City-based technology consulting company,
and has been designing database systems with Oracle since 1997. ObjectArts has worked with many large corporate clients developing XML-based publishing tools and web-based applications. Before ObjectArts, Ben worked with several NYC-based startup companies as a technical lead building content management software.
Christopher G. Chelliah joined Oracle as a Consultant in 1995. He brings with him project management,
architecture, and development experience from a number of large, multinational sites in the mining, oil and gas, and telecom industries. Chris has been involved with emerging and database technologies for his entire career and is an accomplished software architect with a flair for business development. His expertise has been actively sought by a number of major Oracle clients in Australia, Europe, and the United States. Chris, his wife and two kids are currently in Singapore, where he leads a team defining and executing on innovative E-Government strategies for Oracle’s Public Sector industry in Asia Pacific.
Credits
Vice President and Executive Group Publisher Richard Swadley Vice President and Publisher Joseph B. Wikert Executive Editor Robert Elliott Editorial Manager Mary Beth Wakefield Senior Production Editor Geraldine Fahey
Development Editor Sharon Nash Production Editor Felicia Robinson Technical Editors Michael Ault, Tim Gorman, Wiley-Dreamtech India Pvt Ltd Text Design & Composition Wiley Composition Services
Acknowledgments
Although there are a number of names listed on the title page of this book, there are many other people involved in the creation of the work you are currently reading. First and foremost, all of the authors would like to thank Bob Elliott and Sharon Nash for their steady hands on the throttle of this project. Although the birthing of this baby had more than the normal share of labor pains, the worth and beauty of this offspring owes an enormous amount to them. Rick Greenwald, in particular, would like to thank two people. First of all, the process of writing three (is it three already) titles and several revisions of books with Bob Stackowiak has been a wonderful experience, both professionally and personally. I am delighted to count Bob as a friend, and, thanks to him, I still don’t know what BI stands for. Secondly, throughout my writing career, Steven Feurstein has been a mentor as well as a sterling example of what an author and person should be like. I hope to someday reach his level in terms of writing and, even more importantly, humanity. And, of course, I would like to thank my family — LuAnn for helping me have a life that supports writing and working, and Elinor Vera, Josephine, and Robin Greenwald for giving me all the inspiration anyone would ever need. In addition, Rick would like to acknowledge all those people who came through with suggestions and knowledge at crucial times, including Richard Foote, Raj Mattamal and Tyler Muth.
Contents About the Authors v
Acknowledgments ix
Introduction xxvii
Part I: Oracle Essentials xxviii
9 Character Data Types
13
13 Summary
12 Other Data Types
12 RAW and LONG RAW
11 Date Data Types
10 Numeric Data Types
9 BFILE
6 Data Types
Part II: Data Topics xxix
Introduction xxvii
What Does This Book Cover? xxvii Who Is This Book For? xxvii What You Need to Use This Book xxviii How Is This Book Structured? xxviii1 Architecture 2 The Instance
Source Code xxxi Errata xxxi
p2p.wrox.com xxxii
The Bigger Picture xxx
Conventions xxx
Part VI: Optimization xxx
Part V: Business Intelligence Techniques xxx
Part IV: Programming Techniques xxix
Part III: Database Programming Languages xxix
2 Data Organization xii Contents
15 The Processing Cycle for SQL Statements
43 Database Design Phases
37 Isolation Levels
38 Implementation Issues
39 Write Contention
39 Avoiding Changed Data
40 Summary
41 Chapter 4: Database Design Basics
45 Conceptual Database Design
35 Integrity Implications
45 Logical Database Design
45 Physical Design
46 Practical Design
47 Database Design Tools
48 Database Design Techniques
49 Database Design Case Study Example
37 Performance Implications
35 Multiversion Read Consistency
15 Connecting to a Database
23 Parallel Operations
16 Establishing a Cursor
18 Submitting SQL Statements
18 Receiving Data
21 Performance Considerations
21 Retrieval Performance
22 Using Bind Variables
25 Summary
33 Contention 34 The Oracle Solution
26 Chapter 3: Handling Multiple Users
27 Goals
28 Data Integrity
28 Isolation
29 Serialization
29 Transactions 29 Concurrent User Integrity Problems
30 Locks
53
Contents
Normalization 54
56 Second Normal Form
88 Enterprise Security
78 Views
79 Encryption
80 Virtual Private Database
81 Oracle Label Security Option
84 Accountability 85 Auditing
85 Triggers
88 LDAP
75 Stored Procedures
89 Enterprise Users
89 Shared Schemas
89 Database Security
90 Network Security
90 Security Practices
92 Summary
92
78 Access Control
74 Roles
59 Third Normal Form
66 Chapter 5: Oracle Security
60 Other Keys
60 Normalization Summary
62 Defining Additional Entities (Tables)
62 Denormalization 63 Other Physical Design Options
64 Object-Oriented Design Options of Oracle
66 Summary
67 Security Concepts
First Normal Form
67 Confidentiality and Privacy
67 Integrity
68 Why Database-Level Security?
68 Authentication 69 Users and Passwords
69 Smart Cards and Biometric Identification
70 Oracle Syntax
70 Authorization 73 System Privileges
74 Object Privileges Contents Chapter 6: The Oracle Data Dictionary
93 What Is the Data Dictionary?
93 Structure of the Oracle Data Dictionary
94 USER_TABLES
95 ALL_TABLES
96 DBA_TABLES
97 TAB
98 V_$FIXED_TABLE 99 The Oracle Data Dictionary During Development 101
Locating and Describing Data Dictionary Views 101 Which Set of Views? 103 Updating the Data Dictionary 107
The Oracle Data Dictionary at Execution Time 108 SQL to Generate SQL
108 Dynamic SQL 110
Summary 112
Chapter 7: Installing Oracle 113
Getting Oracle Software 113 Installing Oracle Server Software 116
System Requirements 116 Installing the Software 117
Accessing Your Oracle Database 122 Installing Oracle Client Software 123
Java Drivers 124 Oracle Client Software 124 Installing the Instant Client 125 Which Driver? 126
Summary 127
Chapter 8: Introduction to SQL 129
A Bit of History 129 Standards 130
SQL Statement Groupings 130 Data Definition Language (DDL) 131
CREATE 131 ALTER 133 DROP 134 Caveat! 134
Data Manipulation Language (DML) 135 xiv
Contents SQL: Set-Orientated and Nonprocedural
MERGE 171
Index Basics 186
Chapter 10: Indexes 185
Returning Data from Write Operations 183 Additional Extensions 184
Summary 184
How It Works 180 Syntax 180 An Example of Flashback Query 180 Caveats 183 Extended Flashback Capabilities 183
Flashback Query 179
Using ROWNUM 174 Using Analytics 177
TRUNCATE 174
ROWNUM and Ranking 174An Example 172 Caveats 173
INTERSECT 168 MINUS 169
135 SELECT Statement
UNION 166
Extended Set Operations 166
IN and EXISTS 160 ALL, SOME, and ANY 164
LIKE and REGEXP_LIKE 159
Extended Conditions 159
Chapter 9: Extended SQL 159
Summary 156
135 Multi-Table Access 147 Subqueries 150 Insert 153 UPDATE 155 DELETE 155 COMMIT/ROLLBACK/SAVEPOINT 156
How an Index Works 186 Keys 190 Index Attributes 190 xvi Contents
B-Tree Indexes 193
How It Works 193 B-Tree Index Myths 194
Reverse Key Indexes 196 Function-Based Indexes 197
Function-Based Indexes at Work 198 Caveats 201
Domain Indexes 202 Bitmap Indexes 202
The Structure of a Bitmap Index 203 The Impact of a Bitmap Index 204
Bitmap Join Index 206 Index-Organized Tables 207 Index Clusters 207 Hash Cluster 209 Design and Performance Tips 209
Start Small 209 Key Compression 210 SQL Access Advisor 211
Summary 211
213 Database Integrity Features
213 Data Typing
214 Constraints 215 Triggers and Stored Procedures 215
Types of Constraints 216
217 PRIMARY KEY 219 UNIQUE 221 FOREIGN KEY 222 CHECK 226 DEFAULT 230 REF Constraints 231
Working with Constraints 232
Alter Table 233 Constraint States 234 Constraints and Indexes 236 Deferrable Constraints 238 Direct Path Operations 238 Constraints and Export/Import 239 Effect on Mutating Table Triggers 239
Contents Constraints on Views
239 Using Database Constraints for Application-Side Rule Checking 240
Summary 240
Chapter 12: Other Database Structures 241
Tablespaces 241 Temporary Tablespaces 242 Undo Tablespaces 243
Compression 243
Partitioning 245
Views246 Materialized Views 248
Sequences 248
Global Temporary Tables 250 Recycle Bin 250
Synonyms 253
Why Use Synonyms? 253 Working with Synonyms 253
Database Links 255 Advanced Queuing and Streams 255
Streams AQ 255 Streams 256 Streams Summary 258
Objects 258 Stored Procedures, Functions, and Triggers 259
Accessing Flat Files 260
External Tables 260 UTL_FILE 260
SGA Buffer Pool Assignments 260
Workflows 261
Workspace Manager 262
Summary 263
265 What Is a Function?
265 Defining Your Own Functions 265
Permissions to Create Functions 266 Where Can Functions Be Used? 266 Defining a Java Function 267 Viewing Information about Your Functions 267 Deleting a Function 268 xviii Contents
Oracle’s Built-In SQL Functions 268
Aggregate Functions 268 Numeric Functions 275 Character Functions 281 Date and Time Functions 288 Conversion Functions 295 Collection Functions 303 Other Oracle Functions 303
XML Functions 309
Summary 313
Chapter 14: Distributed Queries, Transactions, and Databases 315
Linking Distributed Oracle Databases 316 Distributed Transactions and Two-Phase Commit 319Heterogeneous Services 320
ODBC 321 Transparent Gateways 322
Summary 323
Chapter 15: PL/SQL Basics 325
Code Architecture 325
The Block Header 326 The Declaration Section 328 The Execution Section 328 The Exception Section 329 How Exceptions Are Handled 329 Error-Related Functions 330 Scoping and Notation 330
PL/SQL language 331 Implementing Logic 335
Conditional Logic 335 Branching 338 Iterative 339 Doing Nothing 340
Creating a PL/SQL Program 341
The Purpose of the Sample Procedure 341 Starting the Code 341 Adding Variables 342 Adding Logic 342 Adding Exception Handling 343
Contents Using PL/SQL Code
Using a Single Cursor 353
Implicit Cursors 360 REF CURSORs 362 PL/SQL Records and Collections 363
Syntax 359 Modifying the Example 359
FOR Cursor 359
%TYPE 357 %ROWTYPE 358
Special Data Types 357
Declare Variables 354 Declare Cursor 354 Open a Cursor 354 Fetch 355 Clean Up 356 Running the Procedure 356
Creating a Cursor 352 Opening a Cursor 352 Fetching Data 352 Closing the Cursor 353 Cursor Attributes 353
344 Preparing for Compilation
351 Cursors 352
351 Basic SQL in PL/SQL
Native Compilation 349 Uses of PL/SQL Units 350
Summary 350
Granting Access to PL/SQL units 348 Program Unit Rights 348
Security 348
344 Compiling PL/SQL Code 344 Running PL/SQL Code 345 Compilation, Source Code, and Dependencies 346
PL/SQL Records 363 PL/SQL Records and SQL 364 Associative Arrays 364 Nested Tables 365 Variable Arrays 366 xx Contents
Working with Collections 366 Collection Operations 367 Which Collection Type? 369
An Example 383
Oracle’s Java Architecture 406
Java: The Language 398 Java Virtual Machine and Bytecode 398 What about Performance? 399 J2SE and J2EE 400
Chapter 18: Introduction to Java Database Programming 397
Java Architecture 398Summary 396
Your Second Package 392 Package Code 392 Changing the First Package 393 Impact on the Second Package 394
Using Packages Together 391
The Package Specification 383 The Package Body 384 Running the Example 390
Organization 381 Visibility 381 Scope 381 Dependencies 382 Runtime Memory Usage 382 Oracle’s Endorsement 383
369 Using BULK COLLECT
What Is a Package? 379 Impact of Packages 380
Chapter 17: PL/SQL Packages 379
Summary 376
376 Bulk Operations with Dynamic SQL 376 More on Dynamic SQL 376
Dynamic SQL 375
373 FORALL Enhancements 374
373 Exception Cases
370 FORALL
JDBC and Persistence Frameworks 408
Contents Java outside the Database
Naming Triggers 438 Permissions for Creating Triggers 439 Creating Triggers 439 :new and :old 440 Update Triggers 441 Delete Triggers 441 Controlling When the Trigger Fires 442 Inserting or Updating? 443
Chapter 20: Regular Expressions and Expression Filter 455
Regular Expressions 456Viewing Triggers in the Data Dictionary 452 Limitations of Triggers 453
Summary 453
Deleting/Dropping Triggers 451 Disabling Triggers 451 Recompiling Triggers 452
Triggers in Other Languages 448 Triggers and Mutating Tables 449 Removing Triggers 451
INSTEAD OF Triggers 444 Triggers for Referential Integrity 448
Special Circumstances 443
Working with Triggers 438
411 Java inside the Database 412
Types of Triggers 437 Order of Execution 438
What Are Triggers? 437
Chapter 19: Triggers 437
Summary 434
Java Application Using OracleAS TopLink 419 Java Stored Procedures 427
Setting the CLASSPATH 413 Java Application Using JDBC — Basic Ingredients 414
Building Sample Applications 413
Regular Expression Concepts 457 Relevance to Database Applications 461 Oracle Regular Expressions 462 Usage Scenarios 470 xxii Contents
Architecture and Performance Considerations 475 Expression Filter
Configuration and Run Time 516 Publishing SQL and DML Statements 517 Publishing Java Stored Procedures 518 Publishing Object Types 519 Support for Web Services 520
XML Views 538
Creating XMLType Columns and Tables 537
XMLType 536
Protocol-Based Access to XML in the Oracle Repository 522 SQL-Based Access to XML Data in the Oracle Repository 529 Enabling a New Schema for Use with XDB Repositories 533 ACL-Based Security on Oracle XML Repositories 533
Overview of the XML DB Repository 521
Chapter 22: Oracle XML DB 521
Summary 520
Object Views on Relational Data 511 Oracle JPublisher (JPub) 515
476 Expression Filter Concepts
Existing Java Class as a Persistent Object Type 501 Creating Instances of Object Types in the Database 504 Using Java to Interact with Database Objects 506
Using Oracle Object Types 501
Object Types 490 Object Type Methods 493 Inheritance Support 497 Schema Evolution 499 Mapping to UML Concepts 500
Introducing Oracle Objects 489
ODBMS and RDBMS and ORDBMS 488
Chapter 21: Object Relational Interactions with Oracle 487
Object Relational 488Summary 485
478 Relevance to Database Applications 484
XML Schema 540 SQL/XML and Query Rewrite 533 SQL to XML 554
Contents Transforming XML
557 A Content Management Example 558
Creating the Content Management Application Front End 558 Oracle XML Outside the Database — Oracle XDK 574
Summary 577
Chapter 23: HTML-DB 579
What Is HTML-DB? 579 The HTML-DB Environment 580 Installing HTML-DB 581 Preparing a Development Environment 588
Creating a Workspace 588 Creating an Application Developer 591
Importing Data 593 Creating an Application 599 Functionality in Your HTML-DB Application 610
Adding a New Page 618 Modifying Page Attributes 622 Running the Application 625 Is That All There Is? 626 The Next Step 627
Summary 627
Chapter 24: High-Speed Data Movement 629
Export/Import and the “Data Pump” 630 Transportable Tablespaces 632Usage Considerations 632 Transportable Tablespace Examples 632
Streams 634
Streams Phases and Processes 634 Configuring and Monitoring Advanced Queues 635
Summary 638
Chapter 25: Data Loading and Management 639
SQL*Loader 640 External Table Database Feature 641Defining External Tables 641 Loading from External Tables 642
Transformations 643 Change Data Capture 644 xxiv Chapter # Contents
Partitioning and the Speed of ETL 645 Oracle Warehouse Builder 647
Typical Build and Deploy Steps Using OWB 647 An Example Using OWB 648 Nonrelational Targets 652
Summary 652
Chapter 26: Business Intelligence Query 653
Schema for Business Intelligence 654Dimensions and Hierarchies 658 Creating Dimensions 660
Summary Tables and Materialized Views 661 Using the SQL Access Advisor (Summary Advisor) 663 Creating and Editing Materialized Views
664 Aggregation through SQL: Rollup and Cube 665 Proactive Management of Complex Query Workloads 667 Summary 669
Chapter 27: Business Intelligence Analysis 671
SQL Analytics and Statistics 671Ranking and Percentiles 672 Windows Functions for Cumulative and Moving Aggregates 675
Lag/Lead Analysis 678 First/Last Analysis 679 Linear Regression and Other Advanced Functions 680
OLAP 682 Data Mining 686 Summary 688
Chapter 28: Optimization 689
What Is Optimization? 689 The Oracle Optimizer 690 Optimizer Modes 691
Desupported Optimizer Modes 691 Setting Optimizer Modes 692
Statistics 692
Statistics and Cost 692 Types of Statistics 693 Collecting Statistics 694 Statistics and Change 694
Contents Production and Test Environments
695 Histograms 696 Working with Histograms 696
Execution Plans 699
The Execution Plan 699 Data Operations 700
Execution Statistics 702
Overall Execution Statistics 703 Detailed Statistics 704 Execution Plan and Statistics — An Example 704
Viewing Execution Plans and Statistics 709
AUTOTRACE 709 EXPLAIN PLAN 710 SQL Trace and TKPROF 712 Enterprise Manager 715 V$SQL_PLAN and V$SQL_PLAN_STATISTICS 715
Hints 716
Syntax of a Hint 716 Available Hints 716 Parallel Operations Hints 720 Now Don’t Use Them 721
Stored Outlines 722
Creating Stored Outlines 722 Using Stored Outlines 723 Editing Stored Outlines 723
Summary 723
Index 725Introduction Introduction
Professional Oracle Programming is intended for application developers who use Oracle as their database.
As such, this book does not devote much space to topics which are primarily of interest to database administrators, such as backup and recovery. Most importantly, this book is designed to help a program- mer understand the database issues that can have a direct impact on the operation and performance of their applications.
What Does This Book Cover?
Although it is impossible to cover all the topics that a professional developer could use to the level of depth required in a single book, this volume attempts to provide a foundation for these developers, as well as guidance and examples of some of the key areas of interest and necessity. These areas include accessing data using SQL, handling issues such as multi-user concurrency and data integrity and security, the basics of programming with Java, PL/SQL and XML, and data warehousing. For a more complete list of topics, please refer to the section called “How Is This Book Structured?” later in this introduction.
Who Is This Book For?
The entire topic of Oracle databases is certainly not a new one. Oracle has been one of, if not the, leading databases in the world for almost two decades now. The standard Oracle documentation runs over 13,000 pages, and leaves out a lot of the good stuff. Determining the proper audience for this book, and writing at a level appropriate for that audience, was the biggest conceptual challenge for all of the authors.
Through discussions early in this project, the authors and publishers of this book came up with a fairly distinct profile of our presumed reader. This book is intended for people whose primary job is to create application systems. They are developers, rather than database administrators. Following through on this profile, we believe that you, the professional developer, are well informed and skilled in the creation of these application systems. In our experience, even professional developers may think of the database they use as nothing more than a place to store data. This description of you, the target reader, has guided the selection of topics as well as the actual content of this book. Introduction
What You Need to Use This Book
Although you do not necessarily need to have a working instance of an Oracle database to benefit from this book, the book includes many examples that can be run against your Oracle database. All of the examples have been created against Oracle Database 10g, although, with a few noted exceptions, you could run the examples against Oracle9i. Since Oracle is a cross-platform database, the actual operating system that your version of Oracle runs on is unimportant. All of the examples can be run in either the standard Oracle utilities, such as iSQL*Plus, that come with the product, or a standard development environment, including tools such as TOAD. Directions on how to run the examples are included in Chapter 7 of this book on installing an Oracle database, or in the chapter in which the examples are given. Most of the screen shots in this book have used a Windows client platform, but that platform is simply a standard used for consistency, not a requirement.
How Is This Book Structured?
In a broad sense, this book is divided up into three main areas — information you need to know about how the Oracle database works, information that can help you to use the capabilities of the Oracle database in creating your application systems, and information to help you achieve optimal performance with your application systems. Although these three areas are covered in the order listed in the book, you will find relevant information for each of these areas throughout all of the chapters, along with tips, techniques, and code samples.
Part I: Oracle Essentials Although the Oracle database is a standards-compliant SQL database, the architecture of the Oracle
database and the way it operates include some unique features that are crucial to your effective use of Oracle. The first part of Oracle for Professional Developers covers topics that every developer must understand in order to use the Oracle database effectively. Please don’t think of these chapters as simply introductory material, since some of the information in these chapters can have an enormous effect on the eventual operation of your applications.
The topics covered in this section include: ❑ A brief introduction to the architecture and components of the Oracle database ❑ A detailed look at how Oracle processes your SQL requests and the impact this can have on your application code ❑ A description of how Oracle handles data access by multiple users, and how this impacts your application design ❑ A primer on effective database design ❑ A discussion on how Oracle administers security and how you can use this for your applications
xxviii
Introduction
❑ An overview of the Oracle data dictionary, which contains information about the objects and operations of a specific Oracle database ❑ A brief tutorial on installing an Oracle database
Part II: Data Topics The second section of this book focuses on how to access and manipulate the data in the Oracle
database. The topics in this section are relevant to all developers, regardless of the language they are using to implement their applications. The topics covered in this section include:
❑ An introdution to both basic SQL and some of the more sophisticated uses of this powerful data access language ❑ Indexes, which help to speed the performance of data retrieval ❑ Constraints, which are used to both validate and limit the data added to your Oracle database ❑ A discussion of a variety of other database objects, such as sequences ❑ The use of functions, both built-ins that come with the Oracle database and your own custom defined functions ❑ A discussion of data manipulation as a distributed database environment
Part III: Database Programming Languages The Oracle database allows you to include logic that runs in the database itself.Traditionally, the language
used for this work is PL/SQL — a set of procedural extensions based on the SQL language. Oracle8i introduced a Java engine into the database, which allowed you to use this language for implementing procedural logic in the database.
Part III of this book includes three chapters on PL/SQL and one on Java. The PL/SQL chapters are divided into one on the basics of PL/SQL, one on using PL/SQL in conjunction with SQL, and one of PL/SQL packages, which are a way of organizing and exposing the logic you create with PL/SQL.
Part IV: Programming Techniques Part IV of this book dives into the wide and varied area of implementing logic with various programming techniques to use in the database and your applications. The topics covered include:
❑ The use of triggers, which contain logic that is automatically executed whenever certain types of data access and manipulation are performed ❑ Regular expressions, which are a powerful syntax for implementing matching conditions, and the expression filter — both of these features are new with Oracle Database 10g Introduction
❑ The use of your Oracle database with object types, both for storage and for interactions with objects in your applications ❑ The use of Oracle with XML ❑ HTML-DB, a development environment that comes as part of Oracle Database 10g
Part V: Business Intelligence Techniques Business intelligence describes the process of using raw data in a database as the raw material for analysis
that can affect the direction of business operations. Business intelligence in the Oracle database encompasses the use of several specific features and techniques, which are covered in this section. The topics covered include:
❑ Moving data between different databases, which is often used to take data from an OLTP system to a system used for business intelligence ❑ Data loading and management, which covers the manipulations that are sometimes required to prepare data for use in business intelligence operations ❑ And specific query features used for business intelligence, such as analytic functions
Part VI: Optimization Creating an application is the first part of any programming project. But no application will be acceptable to your constituents if it does not run efficiently. This final section of the book introduces you to the concepts behind optimization in the Oracle database. The chapter includes a discussion of how Oracle determines the optimal access paths to your data, how to see what Oracle has determined, and how to shape the behavior of your Oracle database in this area. Although database optimization is a subject worthy of many excellent volumes, this chapter is intended to give you all the information you need to start to make your applications perform well. The Bigger Picture As mentioned at the start of this introduction, no one book is complete enough to cover everything you
will need to know to use Oracle as an effective database for your applications. We have tried to give you a map that can be used over the course of many years of working with an Oracle database. If you believe that there are destinations we have left off of this map, or descriptions that could be more useful or informative, we welcome your comments.
Conventions
To help you get the most from the text and keep track of what’s happening, we’ve used a number of conventions throughout the book.
xxx
Introduction Boxes like this one hold important, not-to-be forgotten information that is directly relevant to the surrounding text.
Tips, hints, tricks, and asides to the current discussion are offset and placed in italics like this.
As for styles in the text: We highlight important words when we introduce them
❑ We show keyboard strokes like this: Ctrl+A
❑ We show file names, URLs, and code within the text like so:
❑
persistence.properties
We present code in two different ways: ❑
In code examples we highlight new and important code with a gray
background.The gray highlighting is not used for code that’s less important in
the present context, or has been shown before.Source Code
As you work through the examples in this book, you may choose either to type in all the code manually or to use the source code files that accompany the book. All of the source code used in this book is available for download at http://www.wrox.com . Once at the site, simply locate the book’s title (either by using the Search box or by using one of the title lists) and click the Download Code link on the book’s detail page to obtain all the source code for the book.
Because many books have similar titles, you may find it easiest to search by ISBN; for this book the ISBN is 0-7645-7482-5.
Once you download the code, just decompress it with your favorite compression tool. Alternately, you can go to the main Wrox code download page at http://www.wrox.com/dynamic/books/
download.aspx to see the code available for this book and all other Wrox books.
Errata
We make every effort to ensure that there are no errors in the text or in the code. However, no one is perfect, and mistakes do occur. If you find an error in one of our books, like a spelling mistake or faulty piece of code, we would be very grateful for your feedback. By sending in errata you may save another reader hours of frustration and at the same time you will be helping us provide even higher quality information. Introduction
To find the errata page for this book, go to http://www.wrox.com and locate the title using the Search box or one of the title lists. Then, on the book details page, click the Book Errata link. On this page you can view all errata that has been submitted for this book and posted by Wrox editors. A complete book list including links to each book’s errata is also available at www.wrox.com/misc-pages/booklist.shtml .
If you don’t spot “your” error on the Book Errata page, go to www.wrox.com/contact/techsupport.shtml and complete the form there to send us the error you have found. We’ll check the information and, if appropri- ate, post a message to the book’s errata page and fix the problem in subsequent editions of the book.
p2p.wrox.com
For author and peer discussion, join the P2P forums at p2p.wrox.com . The forums are a Web-based system for you to post messages relating to Wrox books and related technologies and interact with other readers and technology users. The forums offer a subscription feature to e-mail you topics of interest of your choosing when new posts are made to the forums. Wrox authors, editors, other industry experts, and your fellow readers are present on these forums. At http://p2p.wrox.com you will find a number of different forums that will help you not only as you read this book, but also as you develop your own applications. To join the forums, just follow these steps:
1. Go to p2p.wrox.com and click the Register link.
Read the terms of use and click Agree.
2.
3. Complete the required information to join as well as any optional information you wish to pro- vide and click Submit.
You will receive an e-mail with information describing how to verify your account and com- 4. plete the joining process.
You can read messages in the forums without joining P2P but in order to post your own messages, you
must join.Once you join, you can post new messages and respond to messages other users post. You can read messages at any time on the Web. If you would like to have new messages from a particular forum e-mailed to you, click the Subscribe to this Forum icon by the forum name in the forum listing. For more information about how to use the Wrox P2P, be sure to read the P2P FAQs for answers to questions about how the forum software works as well as many common questions specific to P2P and Wrox books. To read the FAQs, click the FAQ link on any P2P page.
xxxii
Oracle Architecture and Storage
The core theoretical purpose of a relational database is to separate logical interaction with data within the database from the physical storage of that data. As a user or developer, you shouldn’t really have to know how an Oracle database works internally, or stores its data, in order to use it properly. At a high level, this is certainly true. You don’t need to know anything about the Oracle database to write SQL, the access language used to interact with the database, or to create programs that use SQL.
The Oracle database automatically takes care of translating your logical requests to access the data within its control. But, like all applications, the way your Oracle database is actually implemented can have an impact on what you do and do not do in the creation and maintenance of your application systems. Having a basic understanding of how Oracle does its jobs provides a foundation for the rest of this book. And understanding the ways that Oracle stores your data, which is also covered in this chapter, can have a direct impact on the way you write your applications that use that data.
This first chapter introduces you to a lot of the behind-the-scenes underpinnings of the Oracle database — the architecture of the database and how the data is stored within it. You very well may not ever have to use this information in your day-to-day tasks, but the substance of this chapter is necessary for the more detailed information about programming.
This chapter covers the architecture of the Oracle database as well as the storage options for your data. Depending on how the responsibilities are divided in your particular environment, there may be database administrators (DBAs) who do most of the work of translating your logical requirements into physical storage, or you may be called upon to perform some of these tasks yourself. In either case, this chapter gives you some familiarity with the way your Oracle database handles your data.
Architecture
The Oracle database is a relational database. The theory of relational databases was first put forward by Dr. E. F. Codd, a research scientist working for IBM, in the mid-1970s. Codd proposed a number of rules for a database to follow to be considered a relational database. For the first decade or so after these rules were proposed, early relational databases fought to show that they were the most compliant with Codd’s rules. Those early days are far behind us now, and the basic features of a relational database, such as guar- anteeing transactional integrity and allowing ad hoc access to data, are well established in all major rela- tional databases.
The Oracle database consists of two main parts: the instance, which is the software service that acts as an intermediary between application requests and its data, and the actual data files, which are where the data is kept. The instance is a dynamic process and uses a variety of tasks and memory to support its operations. The data files are stored on disk, so the data itself will survive most service interruptions, except for catastrophic media failure.
The Instance