3 Copyright © 2005, Oracle. All rights reserved. Partitioning Basics.

Slides:



Advertisements
Similar presentations
10 Copyright © 2005, Oracle. All rights reserved. Dimensions.
Advertisements

12 Copyright © 2005, Oracle. All rights reserved. Query Rewrite.
Tuning: overview Rewrite SQL (Leccotech)Leccotech Create Index Redefine Main memory structures (SGA in Oracle) Change the Block Size Materialized Views,
11 Copyright © Oracle Corporation, All rights reserved. Managing Tables.
9 Creating and Managing Tables. Objectives After completing this lesson, you should be able to do the following: Describe the main database objects Create.
What Happens when a SQL statement is issued?
5 Copyright © 2005, Oracle. All rights reserved. Managing Database Storage Structures.
Copyright  Oracle Corporation, All rights reserved. 10 Creating and Managing Tables.
Introduction to Structured Query Language (SQL)
IS 4420 Database Fundamentals Chapter 6: Physical Database Design and Performance Leon Chen.
Oracle Partitioning – Yesterday, Today, and Tomorrow Ananth Raghavan Senior Development Manager, Oracle Partitioning.
1  MyOnlineITCourses.com 1 MyOnlineITCourses.com Oracle Partitioning -- A Primer.
Oracle Database Administration Database files Logical database structures.
Oracle Data Block Oracle Concepts Manual. Oracle Rows Oracle Concepts Manual.
Oracle9i Database Administrator: Implementation and Administration 1 Chapter 9 Index Management.
Basel · Baden · Bern · Lausanne · Zurich · Düsseldorf · Frankfurt/M. · Freiburg i. Br. · Hamburg · Munich · Stuttgart · Vienna Partitioning Your Oracle.
INTRODUCTION TO ORACLE Lynnwood Brown System Managers LLC Application Development For DBA’s Lecture 8 Copyright System Managers LLC 2007 all rights reserved.
Copyright  Oracle Corporation, All rights reserved. 4 CMIS Powell Oracle Designer: Creating the Database Design CMIS Powell.
TM 7-1 Copyright © 1999 Addison Wesley Longman, Inc. Physical Database Design.
1 of 31 Title Slide Learn How To Partition In Oracle 9i Release 2 Reference Number: #31316 By Eric Yen System Consultant Quest Software.
Chapter 6 1 © Prentice Hall, 2002 The Physical Design Stage of SDLC (figures 2.4, 2.5 revisited) Project Identification and Selection Project Initiation.
Oracle9i Database Administrator: Implementation and Administration 1 Chapter 7 Basic Table Management.
Copyright Ó Oracle Corporation, All rights reserved. 22 Running a Form Builder Application.
10 Copyright © 2009, Oracle. All rights reserved. Using DDL Statements to Create and Manage Tables.
1 Copyright © 2006, Oracle. All rights reserved. Using DDL Statements to Create and Manage Tables.
Copyright © 2004, Oracle. All rights reserved. Using DDL Statements to Create and Manage Tables.
Unit 6 Data Storage Design. Key Concepts 1. Database overview 2. SQL review 3. Designing fields 4. Denormalization 5. File organization 6. Object-relational.
10 Creating and Managing Tables Objectives At the end of this lesson, you will be able to: Describe the main database objects Create tables Describe.
7 1 Chapter 7 Introduction to Structured Query Language (SQL) Database Systems: Design, Implementation, and Management, Seventh Edition, Rob and Coronel.
10-1 Copyright  Oracle Corporation, All rights reserved. Database Objects ObjectDescription TableBasic unit of storage; composed of rows and columns.
9 Copyright © Oracle Corporation, All rights reserved. Creating and Managing Tables.
Copyright  Oracle Corporation, All rights reserved. 10 Creating and Managing Tables.
6 1 Lecture 8: Introduction to Structured Query Language (SQL) J. S. Chou, P.E., Ph.D.
Database structure and space Management. Database Structure An ORACLE database has both a physical and logical structure. By separating physical and logical.
Introduction to Oracle. Oracle History 1979 Oracle Release client/server relational database 1989 Oracle Oracle 8 (object relational) 1999.
Oracle 10g Database Administrator: Implementation and Administration Chapter 7 Basic Table Management.
Database Systems Design, Implementation, and Management Coronel | Morris 11e ©2015 Cengage Learning. All Rights Reserved. May not be scanned, copied or.
Commercial RDBMSs Access and Oracle. Access DBMS Architchecture  Can be used as a standalone system on a single PC: -JET Engine -Microsoft Data Engine.
Database Fundamental & Design by A.Surasit Samaisut Copyrights : All Rights Reserved.
14 Copyright © 2006, Oracle. All rights reserved. Tuning Block Space Usage.
5 Copyright © 2005, Oracle. All rights reserved. Managing Database Storage Structures.
Oracle 9i Release 2, A new set of tips, tricks and Techniques. Steve George Sr. Delivery Manager – Oracle University Oracle Corporation Session id: #32681.
D Copyright © Oracle Corporation, All rights reserved. Loading Data into a Database.
9 Copyright © Oracle Corporation, All rights reserved. Creating and Managing Tables.
6 Copyright © 2007, Oracle. All rights reserved. Managing Database Storage Structures.
13 Copyright © Oracle Corporation, All rights reserved. Maintaining Data Integrity.
Physical Database Design Purpose- translate the logical description of data into the technical specifications for storing and retrieving data Goal - create.
Chapter 4 Logical & Physical Database Design
Managing Schema Objects
Chapter 5 Index and Clustering
Session 1 Module 1: Introduction to Data Integrity
9-1 © Prentice Hall, 2007 Topic 9: Physical Database Design Object-Oriented Systems Analysis and Design Joey F. George, Dinesh Batra, Joseph S. Valacich,
Indexes … WHERE key = Table Index 22 Row pointer Key Indexes
1 Copyright © Oracle Corporation, All rights reserved. Writing Basic SQL SELECT Statements.
CERN/IT/DB Oracle9i & VLDB Montse Collados Polidura, IT/DB Database Workshop - July 2001.
Creating and Managing Tables 14. ObjectivesObjectives After completing this lesson, you should be able to do the following: After completing this lesson,
Unit 6 Seminar. Indexed Organized Tables Definition: Index Organized Tables are tables that, unlike heap tables, are organized like B*Tree indexes.
Copyright  Oracle Corporation, All rights reserved. 20 Working with Composite Datatypes.
11-1 © Prentice Hall, 2004 Chapter 11: Physical Database Design Object-Oriented Systems Analysis and Design Joey F. George, Dinesh Batra, Joseph S. Valacich,
8 Copyright © 2005, Oracle. All rights reserved. Gathering Statistics.
 CONACT UC:  Magnific training   
8 Copyright © 2005, Oracle. All rights reserved. Managing Schema Objects.
11 Copyright © 2004, Oracle. All rights reserved. Managing XML Data in an Oracle 10g Database.
9 Copyright © 2006, Oracle. All rights reserved. Summary Management.
11 Copyright © 2009, Oracle. All rights reserved. Enhancing ETL Performance.
CHAPTER 5: PHYSICAL DATABASE DESIGN AND PERFORMANCE
Physical Database Design
Microsoft SQL Server 2014 for Oracle DBAs Module 7
Contents Preface I Introduction Lesson Objectives I-2
Managing Tables.
Presentation transcript:

3 Copyright © 2005, Oracle. All rights reserved. Partitioning Basics

3-2 Copyright © 2005, Oracle. All rights reserved. Objectives After completing this lesson, you should be able to do the following: Outline the Oracle Database partitioning architecture Describe the supported partition List options for creating a partitioned table Create partitioned tables

3-3 Copyright © 2005, Oracle. All rights reserved. Partitioned Tables and Indexes Large tables and indexes can be partitioned into smaller, more manageable pieces. Table T1Index I1 Table T1Index I1

3-4 Copyright © 2005, Oracle. All rights reserved. Manageability: Rolling Window Operations OCT00 JUL01

3-5 Copyright © 2005, Oracle. All rights reserved. Benefits of Partitioning: Performance Considerations The optimizer eliminates (prunes) partitions that do not need to be scanned. Partitions can be scanned, updated, inserted, or deleted in parallel. Join operations can be optimized to join “by the partition.” Partitions can be load-balanced across physical devices.

3-6 Copyright © 2005, Oracle. All rights reserved. Partition pruning: Only the relevant partitions are accessed. Sales 01-May 01-Apr 01-Feb 01-Jan 01-Mar 01-Jun SQL> SELECT SUM(amount_sold) 2 FROM sales 3 WHERE time_id BETWEEN 4 TO_DATE('01-MAR-2000', 5 'DD-MON-YYYY') AND 6 TO_DATE('31-MAY-2000', 7 'DD-MON-YYYY'); Performance Consideration: Partition Pruning

3-7 Copyright © 2005, Oracle. All rights reserved. Table Versus Index Partitioning A nonpartitioned table can have partitioned or nonpartitioned indexes. A partitioned table can have partitioned or nonpartitioned indexes. Table T1 Index I1 Index I2 Table T2 Index I3 Index I4

3-8 Copyright © 2005, Oracle. All rights reserved. Partitioning Methods Range partitioning maps data to partitions on the basis of ranges of partition key values for each partition. Hash partitioning maps data to partitions by using a hashing algorithm applied to a partitioning key. List partitioning maps rows to partitions by using a list of discrete values for the partitioning column. Composite partitioning: –Range-Hash subpartitions the range partitions using a hashing algorithm. –Range-List subpartitions the range partitions using an explicit list.

3-9 Copyright © 2005, Oracle. All rights reserved.

3-10 Copyright © 2005, Oracle. All rights reserved. SQL> CREATE TABLE example 2 ( idx NUMBER, txt VARCHAR2(20) ) 3 PARTITION BY RANGE ( idx ) 4 ( PARTITION VALUES LESS THAN ( 0 ) 5 TABLESPACE data01 6, PARTITION VALUES LESS THAN ( MAXVALUE )); CREATE TABLE Statement with Partitioning A partitioned table declaration contains three elements: The logical structure of the table The partition structure defining the type and columns The structure of each table partition

3-11 Copyright © 2005, Oracle. All rights reserved. Logical and Physical Attributes Logical attributes: Normal table structure (columns, constraints) Partition type Keys and values Row movement Physical attributes: Tablespace Extent sizes, block attributes

3-12 Copyright © 2005, Oracle. All rights reserved. Partitioning Type The partition type is declared in the PARTITION BY clause: SQL> CREATE TABLE ( … column … ) 2 PARTITION BY RANGE ( column_list ) 3 ( PARTITION specifications ) ; 2 PARTITION BY HASH ( column_list ) 2 PARTITION BY LIST ( column ) 2 PARTITION BY RANGE ( column_list ) SUBPARTITION BY HASH ( column_list2 ) 2 PARTITION BY RANGE ( column_list ) SUBPARTITION BY LIST ( column )

3-13 Copyright © 2005, Oracle. All rights reserved. Specifying Partition Attributes Each partition is specified in a partition value clause. There can be up to 65,535 partitions per table.... PARTITION simple_p1 VALUES ( 'HIGH', 'MED' ) TABLESPACE data01 PCTFREE 5, PARTITION simple_p2 VALUES ( 'LOW' ) TABLESPACE data02 STORAGE ( INITIAL 1M )...

3-14 Copyright © 2005, Oracle. All rights reserved. Partition Key Value The partition key value must be a literal. Constant expressions are not allowed, with the exception of TO_DATE conversion. The partition key can consist of up to 16 columns.

3-15 Copyright © 2005, Oracle. All rights reserved. Range Partitioning Specify the columns to be partitioned, and the break values for each partition. Each partition must be defined. The MAXVALUE value allows the greatest possible value and fits all data types. The MAXVALUE value includes NULL values.

3-16 Copyright © 2005, Oracle. All rights reserved. Range Partitioning: Example CREATE TABLE salestable (s_productid NUMBER, s_saledate DATE, s_custid NUMBER, s_totalprice NUMBER) PARTITION BY RANGE(s_saledate) (PARTITION sal99q4 VALUES LESS THAN (TO_DATE('01-JAN- 2000', 'DD-MON-YYYY')), PARTITION sal00q1 VALUES LESS THAN (TO_DATE('01-APR- 2000', 'DD-MON-YYYY')), PARTITION sal00q2 VALUES LESS THAN (TO_DATE('01-JUL- 2000', 'DD-MON-YYYY')), PARTITION sal00q3 VALUES LESS THAN (TO_DATE('01-OCT- 2000', 'DD-MON-YYYY')), PARTITION sal00q4 VALUES LESS THAN (TO_DATE('01-JAN- 2001', 'DD-MON-YYYY')));

3-17 Copyright © 2005, Oracle. All rights reserved. List Partitioning CREATE TABLE sales_list (salesman_id NUMBER(5), salesman_name VARCHAR2(30), sales_state VARCHAR2(20), sales_amount NUMBER(10), sales_date DATE) PARTITION BY LIST(sales_state) (PARTITION sales_west VALUES('California', 'Hawaii'), PARTITION sales_east VALUES ('New York', 'Virginia', 'Florida'), PARTITION sales_central VALUES('Texas', 'Illinois'), PARTITION sales_other VALUES(DEFAULT));

3-18 Copyright © 2005, Oracle. All rights reserved. Hash Partitioning, Named Partitions Specify the columns to be partitioned, and the number of partitions: Partition may be defined, or just quantified. NULL is placed in the first partition. The number of partitions should be a power of two. CREATE TABLE simple (idx NUMBER, txt VARCHAR2(20) PRIMARY KEY) ORGANIZATION INDEX PARTITION BY HASH ( txt ) ( PARTITION s_h1 tablespace data01, PARTITION s_h2 tablespace data03 ) ;

3-19 Copyright © 2005, Oracle. All rights reserved. Hash-Range Partitioning Hash-Range partitioning example: SQL> CREATE TABLE simple 2 ( idx NUMBER, txt VARCHAR2(20) ) 3 PARTITION BY RANGE ( idx ) 4 SUBPARTITION BY HASH ( txt ) 5 SUBPARTITIONS 4 STORE IN (data01, data02) 6 ( PARTITION ns_lo VALUES LESS THAN ( 0 ) 7, PARTITION ns_hi VALUES LESS THAN ( 1E99 ) 8, PARTITION ns_mx 9 VALUES LESS THAN ( MAXVALUE ) 10 SUBPARTITIONS 2 STORE IN ( data03 ) ) ;

3-20 Copyright © 2005, Oracle. All rights reserved. Range-List Partitioning Functionality supported for range-hash partitioning is extended to range-list partitioning. Well suited for: –Historical data at the partition level –Controlled data distribution at subpartition level List (state) Range (year) p1_s1 < 2000 < 2001 < 2002 < 2003 'CA', 'CO' DEFAULT 'FL', 'TX' p1_s2 p1_s3 p2_s1 p2_s2 p2_s3 p3_s1 p3_s2 p3_s3 p4_s1 p4_s2 p4_s3

3-21 Copyright © 2005, Oracle. All rights reserved. Composite Partitioning Using a Template When all partitions have the same subpartition definition, consider using subpartition templates. Templates are useful to avoid defining individual subpartitions. Can be used for: –Range-list partitions –Range-hash partitions Related dictionary view: – DBA_SUBPARTITION_TEMPLATES

3-22 Copyright © 2005, Oracle. All rights reserved. Composite Partitioning and Template: Example CREATE TABLE quarterly_regional_sales ( deptno NUMBER, item VARCHAR2(20), d DATE, amunt NUMBER, state VARCHAR2(2), details CLOB) PARTITION BY RANGE (d) SUBPARTITION BY LIST (state) SUBPARTITION TEMPLATE ( SUBPARTITION northwest VALUES ('OR','WA') TABLESPACE tbs1 LOB (details) STORE AS details1 (TABLESPACE tbs3), SUBPARTITION others VALUES (DEFAULT) TABLESPACE tbs2 LOB (details) STORE AS details7 (TABLESPACE tbs4) ) ( PARTITION q1_2002 VALUES LESS THAN ('01-APR-2002'), PARTITION q2_2002 VALUES LESS THAN ('01-JUL-2002'), PARTITION q3_2002 VALUES LESS THAN ('01-OCT-2002'), PARTITION q4_2002 VALUES LESS THAN ('01-JAN-2003') );

3-23 Copyright © 2005, Oracle. All rights reserved. Partition Extended Table Names Specify the partition in a table to limit an operation: SQL> SELECT idx 2 FROM simple PARTITION ( s_neg ) ; SQL> DELETE FROM simple SUBPARTITION ( s_h2 ) ; SQL> CREATE TABLE sim2 2 AS SELECT * FROM simple PARTITION ( p3 ) ;

Create Partitions with Enterprise Manager

3-25 Copyright © 2005, Oracle. All rights reserved. Equipartitioning If two tables have the same partition keys and partition key values, then they are equipartitioned. This is useful for tables with a common key, like master-detail relationships. A partitionwise join operation requires equipartitioning. Indexes can be equipartitioned with the table.

3-26 Copyright © 2005, Oracle. All rights reserved. Full Partitionwise Joins A full partitionwise join divides a large join into smaller joins. The tables being joined must be equipartitioned on their join keys. When a full partitionwise join is executed in parallel, the granule of parallelism is a partition. SELECT c.cust_last_name, COUNT(*) FROM sales s, customers c WHERE s.cust_id = c.cust_id AND s.time_id BETWEEN TO_DATE('01-JUL-1999', 'DD-MON-YYYY') AND (TO_DATE('01-OCT-1999', 'DD-MON-YYYY')) GROUP BY c.cust_last_name HAVING COUNT(*) > 100;

3-27 Copyright © 2005, Oracle. All rights reserved. Partial Partitionwise Joins Partial partitionwise joins require you to partition only one table on the join key. The partitioned table is called the reference table. The other table is dynamically repartitioned based on the partitioning of the reference table. Partial partitionwise joins can be done only in parallel.

3-28 Copyright © 2005, Oracle. All rights reserved. Summary In this lesson, you should have learned how to: Outline the Oracle Database partitioning architecture Describe the supported partition List options for creating a partitioned table Create partitioned tables

3-29 Copyright © 2005, Oracle. All rights reserved. Practice 3: Overview This practice covers the following topics: Analyzing execution plans involving partition pruning Employing subpartition templates in range-list partitioned table creation

3-30 Copyright © 2005, Oracle. All rights reserved.