DeHaan - Mastering Oracle SQL and ...

DeHaan - Mastering Oracle SQL and SQL Plus (Apress, Databases and SQL
[ Pobierz całość w formacie PDF ]
Mastering Oracle
SQL and SQL*Plus
LEX DE HAAN
Mastering Oracle SQL and SQL*Plus
Copyright © 2005 by Lex de Haan
All rights reserved. No part of this work may be reproduced or transmitted in any form or by any means,
electronic or mechanical, including photocopying, recording, or by any information storage or retrieval
system, without the prior written permission of the copyright owner and the publisher.
ISBN (pbk): 1-59059-448-7
Printed and bound in the United States of America 9 8 7 6 5 4 3 2 1
Trademarked names may appear in this book. Rather than use a trademark symbol with every occurrence
of a trademarked name, we use the names only in an editorial fashion and to the benefit of the trademark
owner, with no intention of infringement of the trademark.
Lead Editor: Tony Davis
Technical Reviewers: Cary Millsap and Joakim Treugut
Editorial Board: Steve Anglin, Dan Appleman, Ewan Buckingham, Gary Cornell, Tony Davis, John Franklin,
Jason Gilmore, Chris Mills, Dominic Shakeshaft, Jim Sumser
Project Manager: Beckie Stones
Copy Edit Manager: Nicole LeClerc
Copy Editor: Marilyn Smith
Production Manager: Kari Brooks-Copony
Production Editor: Kelly Winquist
Compositor: Dina Quan
Proofreader: Liz Welch
Indexer: Michael Brinkman
Artist: Kinetic Publishing
Cover Designer: Kurt Krames
Manufacturing Manager: Tom Debolski
Distributed to the book trade in the United States by Springer-Verlag New York, Inc., 233 Spring Street,
6th Floor, New York, NY 10013, and outside the United States by Springer-Verlag GmbH & Co. KG,
Tiergartenstr. 17, 69112 Heidelberg, Germany.
In the United States: phone 1-800-SPRINGER, fax 201-348-4505, e-mail
orders@springer-ny.com
, or visit
http://www.springer-ny.com
. Outside the United States: fax +49 6221 345229, e-mail
orders@springer.de
,
or visit
http://www.springer.de
.
For information on translations, please contact Apress directly at 2560 Ninth Street, Suite 219, Berkeley,
CA 94710. Phone 510-549-5930, fax 510-549-5939, e-mail
info@apress.com
, or visit
http://www.apress.com
.
The information in this book is distributed on an “as is” basis, without warranty. Although every precaution
has been taken in the preparation of this work, neither the author(s) nor Apress shall have any liability to
any person or entity with respect to any loss or damage caused or alleged to be caused directly or indirectly
by the information contained in this work.
The source code for this book is available to readers at
http://www.apress.com
in the Downloads section,
and also on the author’s web site, at
http://www.naturaljoin.nl
.
Contents at a Glance
Foreword. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . ix
About the Author . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . xi
About the Technical Reviewers. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . xiii
Acknowledgments . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . xv
Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . xvii
CHAPTER 1
Relational Database Systems and Oracle
. . . . . . . . . . . . . . . . . . . . . . . 1
CHAPTER 2
Introduction to SQL,
i
SQL*Plus, and SQL*Plus
. . . . . . . . . . . . . . . . . . 25
CHAPTER 3
Data Definition, Part I
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65
CHAPTER 4
Retrieval: The Basics
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 77
CHAPTER 5
Retrieval: Functions
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 113
CHAPTER 6
Data Manipulation
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 141
CHAPTER 7
Data Definition, Part II
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 159
CHAPTER 8
Retrieval: Multiple Tables and Aggregation
. . . . . . . . . . . . . . . . . . . . 191
CHAPTER 9
Retrieval: Some Advanced Features
. . . . . . . . . . . . . . . . . . . . . . . . . . 233
CHAPTER 10
Views
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 265
CHAPTER 11
SQL*Plus and
i
SQL*Plus
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 289
CHAPTER 12
Object-Relational Features
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 327
APPENDIX A
Quick Reference to SQL and SQL*Plus
. . . . . . . . . . . . . . . . . . . . . . . . 349
APPENDIX B
Data Dictionary Overview
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 373
APPENDIX C
The Seven Case Tables
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 381
APPENDIX D
Answers to the Exercises
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 393
APPENDIX E
Oracle Documentation, Web Sites, and Bibliography
. . . . . . . . . . . 443
INDEX
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 449
iii
Contents
Foreword. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . ix
About the Author . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . xi
About the Technical Reviewers. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . xiii
Acknowledgments . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . xv
Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . xvii
CHAPTER 1
Relational Database Systems and Oracle
. . . . . . . . . . . . . . . . . . 1
1.1 Information Needs and Information Systems
. . . . . . . . . . . . . . . . . . . . . 1
1.2 Database Design
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2
1.3 Database Management Systems
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8
1.4 Relational Database Management Systems
. . . . . . . . . . . . . . . . . . . . . 10
1.5 Relational Data Structures
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11
1.6 Relational Operators
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
1.7 How Relational Is My DBMS?
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16
1.8 The Oracle Software Environment
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18
1.9 Case Tables
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19
CHAPTER 2
Introduction to SQL,
i
SQL*Plus, and SQL*Plus
. . . . . . . . . . . 25
2.1 Overview of SQL
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25
2.2 Basic SQL Concepts and Terminology
. . . . . . . . . . . . . . . . . . . . . . . . . . 32
2.3 Introduction to
i
SQL*Plus
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39
2.4 Introduction to SQL*Plus
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43
CHAPTER 3
Data Definition, Part I
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65
3.1 Schemas and Users
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65
3.2 Table Creation
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 66
3.3 Datatypes
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 67
3.4 Commands for Creating the Case Tables
. . . . . . . . . . . . . . . . . . . . . . . 69
3.5 The Data Dictionary
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 71
v



vi

CONTENTS
CHAPTER 4
Retrieval: The Basics
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 77
4.1 Overview of the SELECT Command
. . . . . . . . . . . . . . . . . . . . . . . . . . . . 77
4.2 The SELECT Clause
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 79
4.3 The WHERE Clause
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 85
4.4 The ORDER BY Clause
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 86
4.5 AND, OR, and NOT
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 89
4.6 BETWEEN, IN, and LIKE
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 93
4.7 CASE Expressions
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 97
4.8 Subqueries
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 100
4.9 Null Values
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 105
4.10 Truth Tables
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 110
4.11 Exercises
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 111
CHAPTER 5
Retrieval: Functions
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 113
5.1 Overview of Functions
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 113
5.2 Arithmetic Functions
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 115
5.3 Text Functions
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 117
5.4 Regular Expressions
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 121
5.5 Date Functions
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 127
5.6 General Functions
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 130
5.7 Conversion Functions
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 132
5.8 Stored Functions
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 137
5.9 Exercises
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 139
CHAPTER 6
Data Manipulation
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 141
6.1 The INSERT Command
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 141
6.2 The UPDATE Command
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 145
6.3 The DELETE Command
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 147
6.4 The MERGE Command
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 149
6.5 Transaction Processing
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 151
6.6 Locking and Read Consistency
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 154
CHAPTER 7
Data Definition, Part II
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 159
7.1 The CREATE TABLE Command
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 159
7.2 More on Datatypes
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 161
7.3 The ALTER TABLE and RENAME Commands
. . . . . . . . . . . . . . . . . . . . 163
7.4 Constraints
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 166
7.5 Indexes
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 174




[ Pobierz całość w formacie PDF ]
  • zanotowane.pl
  • doc.pisz.pl
  • pdf.pisz.pl
  • psdtutoriale.xlx.pl
  • Podstrony
    Powered by wordpress | Theme: simpletex | © Tylko ci którym ufasz, mogą cię zdradzić.