SlideShare a Scribd company logo
1 of 24
Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved.
13
Other Database Objects
13-2 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved.
Objectives
After completing this lesson, you should
be able to do the following:
• Describe some database objects and
their uses
• Create, maintain, and use sequences
• Create and maintain indexes
• Create private and public synonyms
13-3 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved.
Database Objects
Description
Basic unit of storage; composed of rows
and columns
Logically represents subsets of data from
one or more tables
Generates primary key values
Improves the performance of some queries
Alternative name for an object
Object
Table
View
Sequence
Index
Synonym
13-4 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved.
What Is a Sequence?
• Automatically generates unique
numbers
• Is a sharable object
• Is typically used to create a primary key
value
• Replaces application code
• Speeds up the efficiency of accessing
sequence values when cached in
memory
13-5 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved.
The CREATE SEQUENCE
Statement
Define a sequence to generate sequential
numbers automatically.
CREATE SEQUENCE sequence
[INCREMENT BY n]
[START WITH n]
[{MAXVALUE n | NOMAXVALUE}]
[{MINVALUE n | NOMINVALUE}]
[{CYCLE | NOCYCLE}]
[{CACHE n | NOCACHE}];
13-6 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved.
Creating a Sequence
• Create a sequence named DEPT_DEPTNO
to be used for the primary key of the
DEPT table.
• Do not use the CYCLE option.
SQL> CREATE SEQUENCE dept_deptno
2 INCREMENT BY 1
3 START WITH 91
4 MAXVALUE 100
5 NOCACHE
6 NOCYCLE;
Sequence created.
13-7 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved.
Confirming Sequences
• Verify your sequence values in the
USER_SEQUENCES data dictionary
table.
• The LAST_NUMBER column displays
the next available sequence number.
SQL> SELECT sequence_name, min_value, max_value,
2 increment_by, last_number
3 FROM user_sequences;
13-8 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved.
NEXTVAL and CURRVAL
Pseudocolumns
• NEXTVAL returns the next available
sequence value.
It returns a unique value every time it is
referenced, even for different users.
• CURRVAL obtains the current sequence
value.
NEXTVAL must be issued for that
sequence before CURRVAL contains a
value.
13-10 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved.
Using a Sequence
• Insert a new department named
“MARKETING” in San Diego.
• View the current value for the
DEPT_DEPTNO sequence.
SQL> INSERT INTO dept(deptno, dname, loc)
2 VALUES (dept_deptno.NEXTVAL,
3 'MARKETING', 'SAN DIEGO');
1 row created.
SQL> SELECT dept_deptno.CURRVAL
2 FROM dual;
13-11 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved.
Using a Sequence
• Caching sequence values in memory
allows faster access to those values.
• Gaps in sequence values can occur when:
– A rollback occurs
– The system crashes
– A sequence is used in another table
• View the next available sequence, if it was
created with NOCACHE, by querying the
USER_SEQUENCES table.
13-12 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved.
Modifying a Sequence
Change the increment value, maximum
value, minimum value, cycle option, or
cache option.
SQL> ALTER SEQUENCE dept_deptno
2 INCREMENT BY 1
3 MAXVALUE 999999
4 NOCACHE
5 NOCYCLE;
Sequence altered.
13-13 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved.
Guidelines for Modifying
a Sequence
• You must be the owner or have the
ALTER privilege for the sequence.
• Only future sequence numbers are
affected.
• The sequence must be dropped and
re-created to restart the sequence at a
different number.
• Some validation is performed.
13-14 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved.
Removing a Sequence
• Remove a sequence from the data
dictionary by using the DROP
SEQUENCE statement.
• Once removed, the sequence can no
longer be referenced.
SQL> DROP SEQUENCE dept_deptno;
Sequence dropped.
13-15 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved.
What Is an Index?
• Is a schema object
• Is used by the Oracle Server to speed
up the retrieval of rows by using a
pointer
• Can reduce disk I/O by using rapid path
access method to locate the data
quickly
• Is independent of the table it indexes
• Is used and maintained automatically by
the Oracle Server
13-16 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved.
How Are Indexes Created?
• Automatically: A unique index is
created automatically when you define a
PRIMARY KEY or UNIQUE constraint in
a table definition.
• Manually: Users can create nonunique
indexes on columns to speed up access
time to the rows.
13-17 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved.
Creating an Index
• Improve the speed of query access on
the ENAME column in the EMP table.
SQL> CREATE INDEX emp_ename_idx
2 ON emp(ename);
Index created.
CREATE INDEX index
ON table (column[, column]...);
• Create an index on one or more columns.
13-18 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved.
When to Create an Index
• The column is used frequently in the WHERE
clause or in a join condition.
• The column contains a wide range of values.
• The column contains a large number of null
values.
• Two or more columns are frequently used
together in a WHERE clause or a join
condition.
• The table is large and most queries are
expected to retrieve less than 2–4% of the
rows.
13-19 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved.
When Not to Create an Index
• The table is small.
• The columns are not often used as a
condition in the query.
• Most queries are expected to retrieve
more than 2–4% of the rows.
• The table is updated frequently.
13-20 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved.
Confirming Indexes
• The USER_INDEXES data dictionary view
contains the name of the index and its
uniqueness.
• The USER_IND_COLUMNS view contains
the index name, the table name, and the
column name.
SQL> SELECT ic.index_name, ic.column_name,
2 ic.column_position col_pos,ix.uniqueness
3 FROM user_indexes ix, user_ind_columns ic
4 WHERE ic.index_name = ix.index_name
5 AND ic.table_name = 'EMP';
13-21 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved.
Removing an Index
• Remove an index from the data dictionary.
• Remove the EMP_ENAME_IDX index from
the data dictionary.
• To drop an index, you must be the owner
of the index or have the DROP ANY INDEX
privilege.
SQL> DROP INDEX emp_ename_idx;
Index dropped.
SQL> DROP INDEX index;
13-22 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved.
Synonyms
Simplify access to objects by creating a
synonym (another name for an object).
• Refer to a table owned by another user.
• Shorten lengthy object names.
CREATE [PUBLIC] SYNONYM synonym
FOR object;
13-23 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved.
Creating and Removing Synonyms
SQL> CREATE SYNONYM d_sum
2 FOR dept_sum_vu;
Synonym Created.
SQL> DROP SYNONYM d_sum;
Synonym dropped.
• Create a shortened name for the
DEPT_SUM_VU view.
• Drop a synonym.
13-24 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved.
Summary
• Automatically generate sequence
numbers by using a sequence generator.
• View sequence information in the
USER_SEQUENCES data dictionary table.
• Create indexes to improve query retrieval
speed.
• View index information in the
USER_INDEXES dictionary table.
• Use synonyms to provide alternative
names for objects.
13-25 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved.
Practice Overview
• Creating sequences
• Using sequences
• Creating nonunique indexes
• Displaying data dictionary information
about sequences and indexes
• Dropping indexes

More Related Content

What's hot

Commands of DML in SQL
Commands of DML in SQLCommands of DML in SQL
Commands of DML in SQLAshish Gaurkhede
 
Working with Databases and MySQL
Working with Databases and MySQLWorking with Databases and MySQL
Working with Databases and MySQLNicole Ryan
 
Aggregating Data Using Group Functions
Aggregating Data Using Group FunctionsAggregating Data Using Group Functions
Aggregating Data Using Group FunctionsSalman Memon
 
Sql commands
Sql commandsSql commands
Sql commandsPooja Dixit
 
SQL - DML and DDL Commands
SQL - DML and DDL CommandsSQL - DML and DDL Commands
SQL - DML and DDL CommandsShrija Madhu
 
Restricting and Sorting Data - Oracle Data Base
Restricting and Sorting Data - Oracle Data BaseRestricting and Sorting Data - Oracle Data Base
Restricting and Sorting Data - Oracle Data BaseSalman Memon
 
Create table
Create tableCreate table
Create tableNitesh Singh
 
Creating and Managing Tables -Oracle Data base
Creating and Managing Tables -Oracle Data base Creating and Managing Tables -Oracle Data base
Creating and Managing Tables -Oracle Data base Salman Memon
 
SQL JOIN
SQL JOINSQL JOIN
SQL JOINRitwik Das
 
1 - Introduction to PL/SQL
1 - Introduction to PL/SQL1 - Introduction to PL/SQL
1 - Introduction to PL/SQLrehaniltifat
 
Integrity Constraints
Integrity ConstraintsIntegrity Constraints
Integrity Constraintsmadhav bansal
 
Mysql Crud, Php Mysql, php, sql
Mysql Crud, Php Mysql, php, sqlMysql Crud, Php Mysql, php, sql
Mysql Crud, Php Mysql, php, sqlAimal Miakhel
 
Introduction of sql server indexing
Introduction of sql server indexingIntroduction of sql server indexing
Introduction of sql server indexingMahabubur Rahaman
 
database language ppt.pptx
database language ppt.pptxdatabase language ppt.pptx
database language ppt.pptxAnusha sivakumar
 
Retrieving data using the sql select statement
Retrieving data using the sql select statementRetrieving data using the sql select statement
Retrieving data using the sql select statementSyed Zaid Irshad
 
SQL commands
SQL commandsSQL commands
SQL commandsGirdharRatne
 

What's hot (20)

Commands of DML in SQL
Commands of DML in SQLCommands of DML in SQL
Commands of DML in SQL
 
Working with Databases and MySQL
Working with Databases and MySQLWorking with Databases and MySQL
Working with Databases and MySQL
 
Aggregating Data Using Group Functions
Aggregating Data Using Group FunctionsAggregating Data Using Group Functions
Aggregating Data Using Group Functions
 
Sql commands
Sql commandsSql commands
Sql commands
 
set operators.pptx
set operators.pptxset operators.pptx
set operators.pptx
 
SQL - DML and DDL Commands
SQL - DML and DDL CommandsSQL - DML and DDL Commands
SQL - DML and DDL Commands
 
Restricting and Sorting Data - Oracle Data Base
Restricting and Sorting Data - Oracle Data BaseRestricting and Sorting Data - Oracle Data Base
Restricting and Sorting Data - Oracle Data Base
 
Create table
Create tableCreate table
Create table
 
Creating and Managing Tables -Oracle Data base
Creating and Managing Tables -Oracle Data base Creating and Managing Tables -Oracle Data base
Creating and Managing Tables -Oracle Data base
 
Joins in SQL
Joins in SQLJoins in SQL
Joins in SQL
 
SQL JOIN
SQL JOINSQL JOIN
SQL JOIN
 
1 - Introduction to PL/SQL
1 - Introduction to PL/SQL1 - Introduction to PL/SQL
1 - Introduction to PL/SQL
 
Integrity Constraints
Integrity ConstraintsIntegrity Constraints
Integrity Constraints
 
Mysql Crud, Php Mysql, php, sql
Mysql Crud, Php Mysql, php, sqlMysql Crud, Php Mysql, php, sql
Mysql Crud, Php Mysql, php, sql
 
Sql tutorial
Sql tutorialSql tutorial
Sql tutorial
 
Introduction of sql server indexing
Introduction of sql server indexingIntroduction of sql server indexing
Introduction of sql server indexing
 
database language ppt.pptx
database language ppt.pptxdatabase language ppt.pptx
database language ppt.pptx
 
Retrieving data using the sql select statement
Retrieving data using the sql select statementRetrieving data using the sql select statement
Retrieving data using the sql select statement
 
DML, DDL, DCL ,DRL/DQL and TCL Statements in SQL with Examples
DML, DDL, DCL ,DRL/DQL and TCL Statements in SQL with ExamplesDML, DDL, DCL ,DRL/DQL and TCL Statements in SQL with Examples
DML, DDL, DCL ,DRL/DQL and TCL Statements in SQL with Examples
 
SQL commands
SQL commandsSQL commands
SQL commands
 

Similar to Oracle Database Objects - Sequences, Indexes, Synonyms

Les13[1]Other Database Objects
Les13[1]Other Database ObjectsLes13[1]Other Database Objects
Les13[1]Other Database Objectssiavosh kaviani
 
SQL WORKSHOP::Lecture 13
SQL WORKSHOP::Lecture 13SQL WORKSHOP::Lecture 13
SQL WORKSHOP::Lecture 13Umair Amjad
 
Database Objects
Database ObjectsDatabase Objects
Database ObjectsSalman Memon
 
Less07 schema
Less07 schemaLess07 schema
Less07 schemaImran Ali
 
Less08_Schema Advanced Databases and Management.pptx
Less08_Schema Advanced Databases and Management.pptxLess08_Schema Advanced Databases and Management.pptx
Less08_Schema Advanced Databases and Management.pptxMurtazaMughal13
 
Sql views
Sql viewsSql views
Sql viewsarshid045
 
Introduction to SQL, SQL*Plus
Introduction to SQL, SQL*PlusIntroduction to SQL, SQL*Plus
Introduction to SQL, SQL*PlusChhom Karath
 
03 Writing Control Structures, Writing with Compatible Data Types Using Expli...
03 Writing Control Structures, Writing with Compatible Data Types Using Expli...03 Writing Control Structures, Writing with Compatible Data Types Using Expli...
03 Writing Control Structures, Writing with Compatible Data Types Using Expli...rehaniltifat
 
08 Dynamic SQL and Metadata
08 Dynamic SQL and Metadata08 Dynamic SQL and Metadata
08 Dynamic SQL and Metadatarehaniltifat
 
Sql lite android
Sql lite androidSql lite android
Sql lite androidDushyant Nasit
 
Les10[1]Creating and Managing Tables
Les10[1]Creating and Managing TablesLes10[1]Creating and Managing Tables
Les10[1]Creating and Managing Tablessiavosh kaviani
 
Oracle SQL Part1
Oracle SQL Part1Oracle SQL Part1
Oracle SQL Part1Gurpreet singh
 

Similar to Oracle Database Objects - Sequences, Indexes, Synonyms (20)

chap13.ppt
chap13.pptchap13.ppt
chap13.ppt
 
Les13[1]Other Database Objects
Les13[1]Other Database ObjectsLes13[1]Other Database Objects
Les13[1]Other Database Objects
 
SQL WORKSHOP::Lecture 13
SQL WORKSHOP::Lecture 13SQL WORKSHOP::Lecture 13
SQL WORKSHOP::Lecture 13
 
Database Objects
Database ObjectsDatabase Objects
Database Objects
 
Les10
Les10Les10
Les10
 
Less07 schema
Less07 schemaLess07 schema
Less07 schema
 
Less08_Schema Advanced Databases and Management.pptx
Less08_Schema Advanced Databases and Management.pptxLess08_Schema Advanced Databases and Management.pptx
Less08_Schema Advanced Databases and Management.pptx
 
Les11.ppt
Les11.pptLes11.ppt
Les11.ppt
 
Les13
Les13Les13
Les13
 
Sql views
Sql viewsSql views
Sql views
 
Oracle notes
Oracle notesOracle notes
Oracle notes
 
Introduction to SQL, SQL*Plus
Introduction to SQL, SQL*PlusIntroduction to SQL, SQL*Plus
Introduction to SQL, SQL*Plus
 
03 Writing Control Structures, Writing with Compatible Data Types Using Expli...
03 Writing Control Structures, Writing with Compatible Data Types Using Expli...03 Writing Control Structures, Writing with Compatible Data Types Using Expli...
03 Writing Control Structures, Writing with Compatible Data Types Using Expli...
 
Les09.ppt
Les09.pptLes09.ppt
Les09.ppt
 
Overview of Oracle database12c for developers
Overview of Oracle database12c for developersOverview of Oracle database12c for developers
Overview of Oracle database12c for developers
 
08 Dynamic SQL and Metadata
08 Dynamic SQL and Metadata08 Dynamic SQL and Metadata
08 Dynamic SQL and Metadata
 
Sql lite android
Sql lite androidSql lite android
Sql lite android
 
Les10[1]Creating and Managing Tables
Les10[1]Creating and Managing TablesLes10[1]Creating and Managing Tables
Les10[1]Creating and Managing Tables
 
Les12
Les12Les12
Les12
 
Oracle SQL Part1
Oracle SQL Part1Oracle SQL Part1
Oracle SQL Part1
 

More from Balqees Al.Mubarak

More from Balqees Al.Mubarak (9)

Using scripts
Using scriptsUsing scripts
Using scripts
 
Single row functions
Single row functionsSingle row functions
Single row functions
 
Oracle views
Oracle viewsOracle views
Oracle views
 
Lab5 sub query
Lab5   sub queryLab5   sub query
Lab5 sub query
 
Lab4 join - all types listed
Lab4   join - all types listedLab4   join - all types listed
Lab4 join - all types listed
 
Lab3 aggregating data
Lab3   aggregating dataLab3   aggregating data
Lab3 aggregating data
 
Lab2 ddl commands
Lab2 ddl commandsLab2 ddl commands
Lab2 ddl commands
 
Lab1 select statement
Lab1 select statementLab1 select statement
Lab1 select statement
 
Using social network sites
Using social network sites Using social network sites
Using social network sites
 

Recently uploaded

Blooming Together_ Growing a Community Garden Worksheet.docx
Blooming Together_ Growing a Community Garden Worksheet.docxBlooming Together_ Growing a Community Garden Worksheet.docx
Blooming Together_ Growing a Community Garden Worksheet.docxUnboundStockton
 
call girls in Kamla Market (DELHI) 🔝 >༒9953330565🔝 genuine Escort Service 🔝✔️✔️
call girls in Kamla Market (DELHI) 🔝 >༒9953330565🔝 genuine Escort Service 🔝✔️✔️call girls in Kamla Market (DELHI) 🔝 >༒9953330565🔝 genuine Escort Service 🔝✔️✔️
call girls in Kamla Market (DELHI) 🔝 >༒9953330565🔝 genuine Escort Service 🔝✔️✔️9953056974 Low Rate Call Girls In Saket, Delhi NCR
 
Historical philosophical, theoretical, and legal foundations of special and i...
Historical philosophical, theoretical, and legal foundations of special and i...Historical philosophical, theoretical, and legal foundations of special and i...
Historical philosophical, theoretical, and legal foundations of special and i...jaredbarbolino94
 
How to Configure Email Server in Odoo 17
How to Configure Email Server in Odoo 17How to Configure Email Server in Odoo 17
How to Configure Email Server in Odoo 17Celine George
 
Capitol Tech U Doctoral Presentation - April 2024.pptx
Capitol Tech U Doctoral Presentation - April 2024.pptxCapitol Tech U Doctoral Presentation - April 2024.pptx
Capitol Tech U Doctoral Presentation - April 2024.pptxCapitolTechU
 
Meghan Sutherland In Media Res Media Component
Meghan Sutherland In Media Res Media ComponentMeghan Sutherland In Media Res Media Component
Meghan Sutherland In Media Res Media ComponentInMediaRes1
 
Employee wellbeing at the workplace.pptx
Employee wellbeing at the workplace.pptxEmployee wellbeing at the workplace.pptx
Employee wellbeing at the workplace.pptxNirmalaLoungPoorunde1
 
Introduction to ArtificiaI Intelligence in Higher Education
Introduction to ArtificiaI Intelligence in Higher EducationIntroduction to ArtificiaI Intelligence in Higher Education
Introduction to ArtificiaI Intelligence in Higher Educationpboyjonauth
 
Pharmacognosy Flower 3. Compositae 2023.pdf
Pharmacognosy Flower 3. Compositae 2023.pdfPharmacognosy Flower 3. Compositae 2023.pdf
Pharmacognosy Flower 3. Compositae 2023.pdfMahmoud M. Sallam
 
ECONOMIC CONTEXT - PAPER 1 Q3: NEWSPAPERS.pptx
ECONOMIC CONTEXT - PAPER 1 Q3: NEWSPAPERS.pptxECONOMIC CONTEXT - PAPER 1 Q3: NEWSPAPERS.pptx
ECONOMIC CONTEXT - PAPER 1 Q3: NEWSPAPERS.pptxiammrhaywood
 
Painted Grey Ware.pptx, PGW Culture of India
Painted Grey Ware.pptx, PGW Culture of IndiaPainted Grey Ware.pptx, PGW Culture of India
Painted Grey Ware.pptx, PGW Culture of IndiaVirag Sontakke
 
Final demo Grade 9 for demo Plan dessert.pptx
Final demo Grade 9 for demo Plan dessert.pptxFinal demo Grade 9 for demo Plan dessert.pptx
Final demo Grade 9 for demo Plan dessert.pptxAvyJaneVismanos
 
How to Make a Pirate ship Primary Education.pptx
How to Make a Pirate ship Primary Education.pptxHow to Make a Pirate ship Primary Education.pptx
How to Make a Pirate ship Primary Education.pptxmanuelaromero2013
 
Crayon Activity Handout For the Crayon A
Crayon Activity Handout For the Crayon ACrayon Activity Handout For the Crayon A
Crayon Activity Handout For the Crayon AUnboundStockton
 
Like-prefer-love -hate+verb+ing & silent letters & citizenship text.pdf
Like-prefer-love -hate+verb+ing & silent letters & citizenship text.pdfLike-prefer-love -hate+verb+ing & silent letters & citizenship text.pdf
Like-prefer-love -hate+verb+ing & silent letters & citizenship text.pdfMr Bounab Samir
 
Gas measurement O2,Co2,& ph) 04/2024.pptx
Gas measurement O2,Co2,& ph) 04/2024.pptxGas measurement O2,Co2,& ph) 04/2024.pptx
Gas measurement O2,Co2,& ph) 04/2024.pptxDr.Ibrahim Hassaan
 
CELL CYCLE Division Science 8 quarter IV.pptx
CELL CYCLE Division Science 8 quarter IV.pptxCELL CYCLE Division Science 8 quarter IV.pptx
CELL CYCLE Division Science 8 quarter IV.pptxJiesonDelaCerna
 
ENGLISH 7_Q4_LESSON 2_ Employing a Variety of Strategies for Effective Interp...
ENGLISH 7_Q4_LESSON 2_ Employing a Variety of Strategies for Effective Interp...ENGLISH 7_Q4_LESSON 2_ Employing a Variety of Strategies for Effective Interp...
ENGLISH 7_Q4_LESSON 2_ Employing a Variety of Strategies for Effective Interp...JhezDiaz1
 
DATA STRUCTURE AND ALGORITHM for beginners
DATA STRUCTURE AND ALGORITHM for beginnersDATA STRUCTURE AND ALGORITHM for beginners
DATA STRUCTURE AND ALGORITHM for beginnersSabitha Banu
 

Recently uploaded (20)

Blooming Together_ Growing a Community Garden Worksheet.docx
Blooming Together_ Growing a Community Garden Worksheet.docxBlooming Together_ Growing a Community Garden Worksheet.docx
Blooming Together_ Growing a Community Garden Worksheet.docx
 
call girls in Kamla Market (DELHI) 🔝 >༒9953330565🔝 genuine Escort Service 🔝✔️✔️
call girls in Kamla Market (DELHI) 🔝 >༒9953330565🔝 genuine Escort Service 🔝✔️✔️call girls in Kamla Market (DELHI) 🔝 >༒9953330565🔝 genuine Escort Service 🔝✔️✔️
call girls in Kamla Market (DELHI) 🔝 >༒9953330565🔝 genuine Escort Service 🔝✔️✔️
 
Historical philosophical, theoretical, and legal foundations of special and i...
Historical philosophical, theoretical, and legal foundations of special and i...Historical philosophical, theoretical, and legal foundations of special and i...
Historical philosophical, theoretical, and legal foundations of special and i...
 
How to Configure Email Server in Odoo 17
How to Configure Email Server in Odoo 17How to Configure Email Server in Odoo 17
How to Configure Email Server in Odoo 17
 
Capitol Tech U Doctoral Presentation - April 2024.pptx
Capitol Tech U Doctoral Presentation - April 2024.pptxCapitol Tech U Doctoral Presentation - April 2024.pptx
Capitol Tech U Doctoral Presentation - April 2024.pptx
 
Meghan Sutherland In Media Res Media Component
Meghan Sutherland In Media Res Media ComponentMeghan Sutherland In Media Res Media Component
Meghan Sutherland In Media Res Media Component
 
OS-operating systems- ch04 (Threads) ...
OS-operating systems- ch04 (Threads) ...OS-operating systems- ch04 (Threads) ...
OS-operating systems- ch04 (Threads) ...
 
Employee wellbeing at the workplace.pptx
Employee wellbeing at the workplace.pptxEmployee wellbeing at the workplace.pptx
Employee wellbeing at the workplace.pptx
 
Introduction to ArtificiaI Intelligence in Higher Education
Introduction to ArtificiaI Intelligence in Higher EducationIntroduction to ArtificiaI Intelligence in Higher Education
Introduction to ArtificiaI Intelligence in Higher Education
 
Pharmacognosy Flower 3. Compositae 2023.pdf
Pharmacognosy Flower 3. Compositae 2023.pdfPharmacognosy Flower 3. Compositae 2023.pdf
Pharmacognosy Flower 3. Compositae 2023.pdf
 
ECONOMIC CONTEXT - PAPER 1 Q3: NEWSPAPERS.pptx
ECONOMIC CONTEXT - PAPER 1 Q3: NEWSPAPERS.pptxECONOMIC CONTEXT - PAPER 1 Q3: NEWSPAPERS.pptx
ECONOMIC CONTEXT - PAPER 1 Q3: NEWSPAPERS.pptx
 
Painted Grey Ware.pptx, PGW Culture of India
Painted Grey Ware.pptx, PGW Culture of IndiaPainted Grey Ware.pptx, PGW Culture of India
Painted Grey Ware.pptx, PGW Culture of India
 
Final demo Grade 9 for demo Plan dessert.pptx
Final demo Grade 9 for demo Plan dessert.pptxFinal demo Grade 9 for demo Plan dessert.pptx
Final demo Grade 9 for demo Plan dessert.pptx
 
How to Make a Pirate ship Primary Education.pptx
How to Make a Pirate ship Primary Education.pptxHow to Make a Pirate ship Primary Education.pptx
How to Make a Pirate ship Primary Education.pptx
 
Crayon Activity Handout For the Crayon A
Crayon Activity Handout For the Crayon ACrayon Activity Handout For the Crayon A
Crayon Activity Handout For the Crayon A
 
Like-prefer-love -hate+verb+ing & silent letters & citizenship text.pdf
Like-prefer-love -hate+verb+ing & silent letters & citizenship text.pdfLike-prefer-love -hate+verb+ing & silent letters & citizenship text.pdf
Like-prefer-love -hate+verb+ing & silent letters & citizenship text.pdf
 
Gas measurement O2,Co2,& ph) 04/2024.pptx
Gas measurement O2,Co2,& ph) 04/2024.pptxGas measurement O2,Co2,& ph) 04/2024.pptx
Gas measurement O2,Co2,& ph) 04/2024.pptx
 
CELL CYCLE Division Science 8 quarter IV.pptx
CELL CYCLE Division Science 8 quarter IV.pptxCELL CYCLE Division Science 8 quarter IV.pptx
CELL CYCLE Division Science 8 quarter IV.pptx
 
ENGLISH 7_Q4_LESSON 2_ Employing a Variety of Strategies for Effective Interp...
ENGLISH 7_Q4_LESSON 2_ Employing a Variety of Strategies for Effective Interp...ENGLISH 7_Q4_LESSON 2_ Employing a Variety of Strategies for Effective Interp...
ENGLISH 7_Q4_LESSON 2_ Employing a Variety of Strategies for Effective Interp...
 
DATA STRUCTURE AND ALGORITHM for beginners
DATA STRUCTURE AND ALGORITHM for beginnersDATA STRUCTURE AND ALGORITHM for beginners
DATA STRUCTURE AND ALGORITHM for beginners
 

Oracle Database Objects - Sequences, Indexes, Synonyms

  • 1. Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved. 13 Other Database Objects
  • 2. 13-2 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved. Objectives After completing this lesson, you should be able to do the following: • Describe some database objects and their uses • Create, maintain, and use sequences • Create and maintain indexes • Create private and public synonyms
  • 3. 13-3 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved. Database Objects Description Basic unit of storage; composed of rows and columns Logically represents subsets of data from one or more tables Generates primary key values Improves the performance of some queries Alternative name for an object Object Table View Sequence Index Synonym
  • 4. 13-4 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved. What Is a Sequence? • Automatically generates unique numbers • Is a sharable object • Is typically used to create a primary key value • Replaces application code • Speeds up the efficiency of accessing sequence values when cached in memory
  • 5. 13-5 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved. The CREATE SEQUENCE Statement Define a sequence to generate sequential numbers automatically. CREATE SEQUENCE sequence [INCREMENT BY n] [START WITH n] [{MAXVALUE n | NOMAXVALUE}] [{MINVALUE n | NOMINVALUE}] [{CYCLE | NOCYCLE}] [{CACHE n | NOCACHE}];
  • 6. 13-6 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved. Creating a Sequence • Create a sequence named DEPT_DEPTNO to be used for the primary key of the DEPT table. • Do not use the CYCLE option. SQL> CREATE SEQUENCE dept_deptno 2 INCREMENT BY 1 3 START WITH 91 4 MAXVALUE 100 5 NOCACHE 6 NOCYCLE; Sequence created.
  • 7. 13-7 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved. Confirming Sequences • Verify your sequence values in the USER_SEQUENCES data dictionary table. • The LAST_NUMBER column displays the next available sequence number. SQL> SELECT sequence_name, min_value, max_value, 2 increment_by, last_number 3 FROM user_sequences;
  • 8. 13-8 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved. NEXTVAL and CURRVAL Pseudocolumns • NEXTVAL returns the next available sequence value. It returns a unique value every time it is referenced, even for different users. • CURRVAL obtains the current sequence value. NEXTVAL must be issued for that sequence before CURRVAL contains a value.
  • 9. 13-10 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved. Using a Sequence • Insert a new department named “MARKETING” in San Diego. • View the current value for the DEPT_DEPTNO sequence. SQL> INSERT INTO dept(deptno, dname, loc) 2 VALUES (dept_deptno.NEXTVAL, 3 'MARKETING', 'SAN DIEGO'); 1 row created. SQL> SELECT dept_deptno.CURRVAL 2 FROM dual;
  • 10. 13-11 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved. Using a Sequence • Caching sequence values in memory allows faster access to those values. • Gaps in sequence values can occur when: – A rollback occurs – The system crashes – A sequence is used in another table • View the next available sequence, if it was created with NOCACHE, by querying the USER_SEQUENCES table.
  • 11. 13-12 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved. Modifying a Sequence Change the increment value, maximum value, minimum value, cycle option, or cache option. SQL> ALTER SEQUENCE dept_deptno 2 INCREMENT BY 1 3 MAXVALUE 999999 4 NOCACHE 5 NOCYCLE; Sequence altered.
  • 12. 13-13 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved. Guidelines for Modifying a Sequence • You must be the owner or have the ALTER privilege for the sequence. • Only future sequence numbers are affected. • The sequence must be dropped and re-created to restart the sequence at a different number. • Some validation is performed.
  • 13. 13-14 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved. Removing a Sequence • Remove a sequence from the data dictionary by using the DROP SEQUENCE statement. • Once removed, the sequence can no longer be referenced. SQL> DROP SEQUENCE dept_deptno; Sequence dropped.
  • 14. 13-15 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved. What Is an Index? • Is a schema object • Is used by the Oracle Server to speed up the retrieval of rows by using a pointer • Can reduce disk I/O by using rapid path access method to locate the data quickly • Is independent of the table it indexes • Is used and maintained automatically by the Oracle Server
  • 15. 13-16 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved. How Are Indexes Created? • Automatically: A unique index is created automatically when you define a PRIMARY KEY or UNIQUE constraint in a table definition. • Manually: Users can create nonunique indexes on columns to speed up access time to the rows.
  • 16. 13-17 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved. Creating an Index • Improve the speed of query access on the ENAME column in the EMP table. SQL> CREATE INDEX emp_ename_idx 2 ON emp(ename); Index created. CREATE INDEX index ON table (column[, column]...); • Create an index on one or more columns.
  • 17. 13-18 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved. When to Create an Index • The column is used frequently in the WHERE clause or in a join condition. • The column contains a wide range of values. • The column contains a large number of null values. • Two or more columns are frequently used together in a WHERE clause or a join condition. • The table is large and most queries are expected to retrieve less than 2–4% of the rows.
  • 18. 13-19 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved. When Not to Create an Index • The table is small. • The columns are not often used as a condition in the query. • Most queries are expected to retrieve more than 2–4% of the rows. • The table is updated frequently.
  • 19. 13-20 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved. Confirming Indexes • The USER_INDEXES data dictionary view contains the name of the index and its uniqueness. • The USER_IND_COLUMNS view contains the index name, the table name, and the column name. SQL> SELECT ic.index_name, ic.column_name, 2 ic.column_position col_pos,ix.uniqueness 3 FROM user_indexes ix, user_ind_columns ic 4 WHERE ic.index_name = ix.index_name 5 AND ic.table_name = 'EMP';
  • 20. 13-21 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved. Removing an Index • Remove an index from the data dictionary. • Remove the EMP_ENAME_IDX index from the data dictionary. • To drop an index, you must be the owner of the index or have the DROP ANY INDEX privilege. SQL> DROP INDEX emp_ename_idx; Index dropped. SQL> DROP INDEX index;
  • 21. 13-22 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved. Synonyms Simplify access to objects by creating a synonym (another name for an object). • Refer to a table owned by another user. • Shorten lengthy object names. CREATE [PUBLIC] SYNONYM synonym FOR object;
  • 22. 13-23 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved. Creating and Removing Synonyms SQL> CREATE SYNONYM d_sum 2 FOR dept_sum_vu; Synonym Created. SQL> DROP SYNONYM d_sum; Synonym dropped. • Create a shortened name for the DEPT_SUM_VU view. • Drop a synonym.
  • 23. 13-24 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved. Summary • Automatically generate sequence numbers by using a sequence generator. • View sequence information in the USER_SEQUENCES data dictionary table. • Create indexes to improve query retrieval speed. • View index information in the USER_INDEXES dictionary table. • Use synonyms to provide alternative names for objects.
  • 24. 13-25 Copyright ‫س‬ Oracle Corporation, 1998. All rights reserved. Practice Overview • Creating sequences • Using sequences • Creating nonunique indexes • Displaying data dictionary information about sequences and indexes • Dropping indexes