SlideShare a Scribd company logo
ther Database Object
http://ecomputernotes.com
Objectives
After completing this lesson, you should be able to
do the following:
" Create, maintain, and use sequences
" Create and maintain indexes
" Create private and public synonyms
http://ecomputernotes.com
Database Objects
Object Description
Basic unit of storage; composed of rowsTable
and columns
View Logically represents subsets of data from
one or more tables
Generates primary key valuesSequence
Index Improves the performance of some queries
Synonym Alternative name for an object
http://ecomputernotes.com
What Is a Sequence?
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
http://ecomputernotes.com
The CREATE SEQUENCE Statement Syntax
Define a sequence to generate sequential numbers
automatically:
CREATE SEQUENCE sequence
[INCREMENT BY n]
[START WITH n]
[START WITH n]
[{MAXVALUE n | NOMAXVALUE}]
[{MINVALUE n | NOMINVALUE}]
[{CYCLE | NOCYCLE}]
[{CACHE n | NOCACHE}];
http://ecomputernotes.com
Creating a Sequence
" Create a sequence named DEPT_DEPTID_SEQ to be
used for the primary key of the DEPARTMENTS table.
" Do not use the CYCLE option.
CREATE SEQUENCE dept_deptid_seq
INCREMENT BY 10
START WITH 120
START WITH 120
MAXVALUE 9999
NOCACHE
NOCYCLE;
Sequence created.
http://ecomputernotes.com
Confirming Sequences
" Verify your sequence values in the
USER_SEQUENCES data dictionary table.
SELECT sequence_name, min_value, max_value,
increment_by, last_number
FRO M user_sequences;
" The LAST_NUMBER column displays the next
available sequence number if NOCACHE is
specified.
http://ecomputernotes.com
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.
http://ecomputernotes.com
Using a Sequence
" Insert a new department named ³Support´ in
location ID 2500.
INSERT INTO departments(department_id,
department_name, location_id)
VALUES (dept_deptid_seq.NEXTVAL,
'Support', 2500);
1 row created.
" View the current value for the DEPT_DEPTID_SEQ
sequence.
SELECT dept_deptid_seq.CURRVAL
FROM dual;
http://ecomputernotes.com
Using a Sequence
"Caching sequence values in memory gives 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
" If the sequence was created with NOCACHE, view
the next available value, by querying the
USER_SEQUENCES table.
http://ecomputernotes.com
Modifying a Sequence
Change the increment value, maximum value,
minimum value, cycle option, or cache option.
ALTER SEQUENCE dept_deptid_seq
INCREMENT BY 20
MAXVALUE 999999
NOCACHE
NOCYCLE;
Sequence altered.
http://ecomputernotes.com
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.
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.
DROP SEQUENCE dept_deptid_seq;
Sequence dropped.
What is an Index?
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 a rapid path access
method to locate data quickly
" Is independent of the table it indexes
" Is used and maintained automatically by the
Oracle server
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 to the rows.
Creating an Index
"Create an index on one or more columns.
CREATE INDEXindex
ON table (column[, column]...);
"Improve the speed of query access to the
LAST_NAME column in the EMPLOYEES table.
CREATE INDEX emp_last_name_idx
ON employees(last_name);
Index created.
When to Create an Index
You should create an index if:
" A column contains a wide range of values
" A column contains a large number of null values
" One 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 to 4 percent of the rows
When Not to Create an Index
It is usually not worth creating an index if:
" 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
to 4 percent of the rows in the table
" The table is updated frequently
" The indexed columns are referenced as part of an
expression
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.
SELECT ic.index_name, ic.column_name,
ic.column_position col_pos,ix.uniqueness
FRO M user_indexes ix, user_ind_columns ic
WHERE ic.index_name = ix.index_name
AND ic.table_name = 'EMPLOYEES';
Function-Based Indexes
"A function-based index is an index based on
expressions.
"The index expression is built from table columns,
constants, SQL functions, and user-defined
functions.
CREATE INDEX upper_dept_name_idx ON
departments(UPPER(department_name));
Index created.
SELECT *
FROM departments
WHERE UPPER(department_name) = 'SALES';
Removing an Index
"Remove an index from the data dictionary by
using the DROP INDEX command.
DROP INDEX index;
"Remove the UPPER_LAST_NAME_IDX index from
the data dictionary.
DROP INDEX upper_last_name_idx;
Index dropped.
"To drop an index, you must be the owner of the
index or have the DROP ANY INDEX privilege.
Synonyms
Simplify access to objects by creating a synonym
(another name for an object). With synonyms, you can:
" Ease referring to a table owned by another user
"Shorten lengthy object names
CREATE [PUBLIC] SYNONY M synonym
FOR object;
Creating and Removing Synonyms
"Create a shortened name for the
DEPT_SUM_VU view.
CREATE SYNONYM d_sum
FOR dept_sum_vu;
Synonym Created.
" Drop a synonym.
DROP SYNONYM d_sum;
Synonym dropped.

More Related Content

PPTX
PPTX
09.1. Android - Local Database (Sqlite)
DOCX
Accessing data with android cursors
PPTX
07.3. Android Alert message, List, Dropdown, and Auto Complete
PPTX
Sub-Queries
PDF
Autonumber
PPTX
Sql subquery
DOCX
Oracle ebs how to obtain environment variable value using sql query
09.1. Android - Local Database (Sqlite)
Accessing data with android cursors
07.3. Android Alert message, List, Dropdown, and Auto Complete
Sub-Queries
Autonumber
Sql subquery
Oracle ebs how to obtain environment variable value using sql query

What's hot (15)

PDF
Web Application Security 101 - 14 Data Validation
PPSX
ASP.Net Presentation Part2
PPTX
Lab2 ddl commands
PPT
Sql views
PPTX
Mule system properties
PDF
How to Create and Load Model in Laravel
PDF
IR SQLite Session #1
PDF
PHP with MySQL
PPTX
How mysql choose the execution plan
PDF
MySQL Query And Index Tuning
ODP
Database index by Reema Gajjar
PPTX
Scalar user defined function in sap hana
PPT
Ajax
PDF
JavaStates Simple Tutorial
Web Application Security 101 - 14 Data Validation
ASP.Net Presentation Part2
Lab2 ddl commands
Sql views
Mule system properties
How to Create and Load Model in Laravel
IR SQLite Session #1
PHP with MySQL
How mysql choose the execution plan
MySQL Query And Index Tuning
Database index by Reema Gajjar
Scalar user defined function in sap hana
Ajax
JavaStates Simple Tutorial
Ad

Viewers also liked (13)

DOC
computer notes - Processes and process management
PDF
computer notes - Circular list
PPT
Computer notes - data structures
PDF
computer notes - Stack
DOC
computer notes - File systems and management
DOC
e computer notes - Operations on binary tree
PDF
computer notes - Priority queue
PPT
Computer notes - Reference Variables –II
PPT
Computer notes - Maze Generator
PPT
Computer notes - singleRightRotation
PDF
computer notes - Linked list
PPT
Computer notes - Analysis of Union
DOC
computer notes - Introduction to operating system
computer notes - Processes and process management
computer notes - Circular list
Computer notes - data structures
computer notes - Stack
computer notes - File systems and management
e computer notes - Operations on binary tree
computer notes - Priority queue
Computer notes - Reference Variables –II
Computer notes - Maze Generator
Computer notes - singleRightRotation
computer notes - Linked list
Computer notes - Analysis of Union
computer notes - Introduction to operating system
Ad

Similar to e computer notes - Other database objects (20)

PPT
1_SQL_11_13_Notes_on_how_to_gain_knowledge.ppt
PPT
PPT
PPT
Database Objects
PDF
[2015/2016] Local data storage for web-based mobile apps
PPT
DOCX
DBMS LAB M.docx
PPT
SQL WORKSHOP::Lecture 13
PPT
PPT
Creating other schema objects
PDF
Local Storage
DOCX
Android database tutorial
PPT
MYSQL - PHP Database Connectivity
PPT
Sequences and indexes
PPT
Les13[1]Other Database Objects
PPTX
7. SQL.pptx
PDF
PHP and Mysql
PPT
Myth busters - performance tuning 101 2007
PPTX
Learn PHP Lacture2
PPT
PHP - Getting good with MySQL part II
1_SQL_11_13_Notes_on_how_to_gain_knowledge.ppt
Database Objects
[2015/2016] Local data storage for web-based mobile apps
DBMS LAB M.docx
SQL WORKSHOP::Lecture 13
Creating other schema objects
Local Storage
Android database tutorial
MYSQL - PHP Database Connectivity
Sequences and indexes
Les13[1]Other Database Objects
7. SQL.pptx
PHP and Mysql
Myth busters - performance tuning 101 2007
Learn PHP Lacture2
PHP - Getting good with MySQL part II

More from ecomputernotes (20)

PPT
computer notes - Data Structures - 30
PPT
computer notes - Data Structures - 39
PPT
computer notes - Data Structures - 11
PPT
computer notes - Data Structures - 20
PPT
computer notes - Data Structures - 15
DOC
Computer notes - Including Constraints
DOC
Computer notes - Date time Functions
DOC
Computer notes - Subqueries
DOC
Computer notes - Other Database Objects
PPT
computer notes - Data Structures - 28
PPT
computer notes - Data Structures - 19
PPT
computer notes - Data Structures - 31
PPT
computer notes - Data Structures - 4
PPT
computer notes - Data Structures - 13
DOC
Computer notes - Advanced Subqueries
DOC
Computer notes - Aggregating Data Using Group Functions
PPT
computer notes - Data Structures - 16
PPT
computer notes - Data Structures - 22
PPT
computer notes - Data Structures - 35
PPT
computer notes - Data Structures - 36
computer notes - Data Structures - 30
computer notes - Data Structures - 39
computer notes - Data Structures - 11
computer notes - Data Structures - 20
computer notes - Data Structures - 15
Computer notes - Including Constraints
Computer notes - Date time Functions
Computer notes - Subqueries
Computer notes - Other Database Objects
computer notes - Data Structures - 28
computer notes - Data Structures - 19
computer notes - Data Structures - 31
computer notes - Data Structures - 4
computer notes - Data Structures - 13
Computer notes - Advanced Subqueries
Computer notes - Aggregating Data Using Group Functions
computer notes - Data Structures - 16
computer notes - Data Structures - 22
computer notes - Data Structures - 35
computer notes - Data Structures - 36

Recently uploaded (20)

PDF
The Lost Whites of Pakistan by Jahanzaib Mughal.pdf
PDF
2.FourierTransform-ShortQuestionswithAnswers.pdf
PDF
Saundersa Comprehensive Review for the NCLEX-RN Examination.pdf
PDF
Microbial disease of the cardiovascular and lymphatic systems
PPTX
Final Presentation General Medicine 03-08-2024.pptx
PDF
FourierSeries-QuestionsWithAnswers(Part-A).pdf
PPTX
1st Inaugural Professorial Lecture held on 19th February 2020 (Governance and...
PPTX
PPT- ENG7_QUARTER1_LESSON1_WEEK1. IMAGERY -DESCRIPTIONS pptx.pptx
PDF
A systematic review of self-coping strategies used by university students to ...
PDF
VCE English Exam - Section C Student Revision Booklet
PPTX
Lesson notes of climatology university.
PDF
01-Introduction-to-Information-Management.pdf
PDF
Computing-Curriculum for Schools in Ghana
PDF
O5-L3 Freight Transport Ops (International) V1.pdf
PDF
Abdominal Access Techniques with Prof. Dr. R K Mishra
PDF
GENETICS IN BIOLOGY IN SECONDARY LEVEL FORM 3
PPTX
Cell Structure & Organelles in detailed.
PDF
grade 11-chemistry_fetena_net_5883.pdf teacher guide for all student
PDF
3rd Neelam Sanjeevareddy Memorial Lecture.pdf
PPTX
Institutional Correction lecture only . . .
The Lost Whites of Pakistan by Jahanzaib Mughal.pdf
2.FourierTransform-ShortQuestionswithAnswers.pdf
Saundersa Comprehensive Review for the NCLEX-RN Examination.pdf
Microbial disease of the cardiovascular and lymphatic systems
Final Presentation General Medicine 03-08-2024.pptx
FourierSeries-QuestionsWithAnswers(Part-A).pdf
1st Inaugural Professorial Lecture held on 19th February 2020 (Governance and...
PPT- ENG7_QUARTER1_LESSON1_WEEK1. IMAGERY -DESCRIPTIONS pptx.pptx
A systematic review of self-coping strategies used by university students to ...
VCE English Exam - Section C Student Revision Booklet
Lesson notes of climatology university.
01-Introduction-to-Information-Management.pdf
Computing-Curriculum for Schools in Ghana
O5-L3 Freight Transport Ops (International) V1.pdf
Abdominal Access Techniques with Prof. Dr. R K Mishra
GENETICS IN BIOLOGY IN SECONDARY LEVEL FORM 3
Cell Structure & Organelles in detailed.
grade 11-chemistry_fetena_net_5883.pdf teacher guide for all student
3rd Neelam Sanjeevareddy Memorial Lecture.pdf
Institutional Correction lecture only . . .

e computer notes - Other database objects

  • 2. Objectives After completing this lesson, you should be able to do the following: " Create, maintain, and use sequences " Create and maintain indexes " Create private and public synonyms http://ecomputernotes.com
  • 3. Database Objects Object Description Basic unit of storage; composed of rowsTable and columns View Logically represents subsets of data from one or more tables Generates primary key valuesSequence Index Improves the performance of some queries Synonym Alternative name for an object http://ecomputernotes.com
  • 4. What Is a Sequence? 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 http://ecomputernotes.com
  • 5. The CREATE SEQUENCE Statement Syntax Define a sequence to generate sequential numbers automatically: CREATE SEQUENCE sequence [INCREMENT BY n] [START WITH n] [START WITH n] [{MAXVALUE n | NOMAXVALUE}] [{MINVALUE n | NOMINVALUE}] [{CYCLE | NOCYCLE}] [{CACHE n | NOCACHE}]; http://ecomputernotes.com
  • 6. Creating a Sequence " Create a sequence named DEPT_DEPTID_SEQ to be used for the primary key of the DEPARTMENTS table. " Do not use the CYCLE option. CREATE SEQUENCE dept_deptid_seq INCREMENT BY 10 START WITH 120 START WITH 120 MAXVALUE 9999 NOCACHE NOCYCLE; Sequence created. http://ecomputernotes.com
  • 7. Confirming Sequences " Verify your sequence values in the USER_SEQUENCES data dictionary table. SELECT sequence_name, min_value, max_value, increment_by, last_number FRO M user_sequences; " The LAST_NUMBER column displays the next available sequence number if NOCACHE is specified. http://ecomputernotes.com
  • 8. 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. http://ecomputernotes.com
  • 9. Using a Sequence " Insert a new department named ³Support´ in location ID 2500. INSERT INTO departments(department_id, department_name, location_id) VALUES (dept_deptid_seq.NEXTVAL, 'Support', 2500); 1 row created. " View the current value for the DEPT_DEPTID_SEQ sequence. SELECT dept_deptid_seq.CURRVAL FROM dual; http://ecomputernotes.com
  • 10. Using a Sequence "Caching sequence values in memory gives 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 " If the sequence was created with NOCACHE, view the next available value, by querying the USER_SEQUENCES table. http://ecomputernotes.com
  • 11. Modifying a Sequence Change the increment value, maximum value, minimum value, cycle option, or cache option. ALTER SEQUENCE dept_deptid_seq INCREMENT BY 20 MAXVALUE 999999 NOCACHE NOCYCLE; Sequence altered. http://ecomputernotes.com
  • 12. 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. 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. DROP SEQUENCE dept_deptid_seq; Sequence dropped.
  • 14. What is an Index? 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 a rapid path access method to locate data quickly " Is independent of the table it indexes " Is used and maintained automatically by the Oracle server
  • 15. 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 to the rows.
  • 16. Creating an Index "Create an index on one or more columns. CREATE INDEXindex ON table (column[, column]...); "Improve the speed of query access to the LAST_NAME column in the EMPLOYEES table. CREATE INDEX emp_last_name_idx ON employees(last_name); Index created.
  • 17. When to Create an Index You should create an index if: " A column contains a wide range of values " A column contains a large number of null values " One 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 to 4 percent of the rows
  • 18. When Not to Create an Index It is usually not worth creating an index if: " 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 to 4 percent of the rows in the table " The table is updated frequently " The indexed columns are referenced as part of an expression
  • 19. 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. SELECT ic.index_name, ic.column_name, ic.column_position col_pos,ix.uniqueness FRO M user_indexes ix, user_ind_columns ic WHERE ic.index_name = ix.index_name AND ic.table_name = 'EMPLOYEES';
  • 20. Function-Based Indexes "A function-based index is an index based on expressions. "The index expression is built from table columns, constants, SQL functions, and user-defined functions. CREATE INDEX upper_dept_name_idx ON departments(UPPER(department_name)); Index created. SELECT * FROM departments WHERE UPPER(department_name) = 'SALES';
  • 21. Removing an Index "Remove an index from the data dictionary by using the DROP INDEX command. DROP INDEX index; "Remove the UPPER_LAST_NAME_IDX index from the data dictionary. DROP INDEX upper_last_name_idx; Index dropped. "To drop an index, you must be the owner of the index or have the DROP ANY INDEX privilege.
  • 22. Synonyms Simplify access to objects by creating a synonym (another name for an object). With synonyms, you can: " Ease referring to a table owned by another user "Shorten lengthy object names CREATE [PUBLIC] SYNONY M synonym FOR object;
  • 23. Creating and Removing Synonyms "Create a shortened name for the DEPT_SUM_VU view. CREATE SYNONYM d_sum FOR dept_sum_vu; Synonym Created. " Drop a synonym. DROP SYNONYM d_sum; Synonym dropped.