Introduction to Oracle
What is Oracle ?
Oracle is a relational database management system.
• It is a management system which uses the relational
data model.
• In the relational data model, data is seen by the users
in form of tables alone.
Oracle Server:
• Is a database management system that provides an open,
comprehensive, integrated approach to information
management.
• Consists of an Oracle Instance and an Oracle database
Oracle in Industry
• In today’s world, data is the key for business
• Every organization stores its data in multiple databases
• One of the most widely used database in industry is Oracle
• Oracle can work on various Operating Systems (Windows, Unix, etc.)
• The demand for Oracle in today’s world is immense
• Many projects across the industry use Oracle as back-end for deploying
its various applications.
Database Architecture - Introduction
Database Instance:
• Oracle Database consists of Software Modules & Database Files
• Instance –After the complete installation of Oracle 11g, when you start
the Oracle database , then you have what is referred to as an“Oracle
11g Database Instance”. It is the actual execution of DBMS software
that manages data in the databases tablespace.
Properties Of Database Instance
1. Created on loading the software from disk to
memory.
2. It is an aggregation of processes and memory
structures
3. It is sharable thus allowing multiple users to access
the same database.
Memory Components and Background Processes
• Two Main Components:
1. SGA( System Global Area)
-a group of shared memory structures that contain data and control
information for an Oracle database instance.
-the data in the instance's SGA is shared among the multiple concurrent
users.
-allocated when you start the database instance.
-de-allocated when the instance is shutdown.
2. PGA (Program Global Area)
-Each server process has a PGA allocated that is a private area for
each server
-Work area for each application.
Types of files
Control Files
• Purpose:
- contain a list of all other files that make up the database such as data files and
Redo Log files.
-also contain important information about the contents and operating state of the
database.
• The data includes:-
1. By default, an Oracle 11g database creates three control files,CONTROL01.CTL,
CONTROL02.CTL and CONTROL03.CTL and they are mirror images of each
other.
2. The name of the database
3. Date the database was created
4. Current state of the database: read-only
5. Database status when last closed
6. Backups performed
7. Since this is a critical file you should have more than one control file and they
should be on separate disk drives
8. Have a .ctl suffix
Data Files
• Purpose:
-contain the actual data stored in the database.
-contains user data stored in tables + includes indexes, data dictionary,
and rollback segments.
• Characteristics:
1. Data files are composed of Oracle blocks.
2. Oracle block sizes range from 2 Kb to 32 Kb – average size is 8 Kb
3. When you map out a database onto the OS I/O sub-systems, the
smallest unit you can put in any location is a data file
4. Have a .dbf suffix
Redo Log Filesq
• Purpose:
- store changes made to the database as a result of transaction and internal
Oracle activities.
• Characteristics:
1. By default, an Oracle 11g database contains three redo log groups,
REDO01.log, REDO02.log and REDO03.log
2. As a general rule , there should be one redo log group for approximately every
four database users that create action queries
3. Oracle 10g keeps track of the Redo Log file by using a redo log sequence
number, this number is recorded inside the file as they are used
4. Have a .log suffix
Data Structures
Database
Instance
Tablespaces
Tablespaces
Segments
Extents
Extents
Data
Blocks Data
Extents Blocks
Extents
Data
Blocks Data
Data Blocks
Blocks
TABLESPACE SEGMENT EXTENTS and DATA BLOCKS
• Tablespace is used to store related database objects. One tablespace is used to store
all of the system tables; another tablespace may be created for all indexes or a
tablespace may be created to store all of the tables for a specific application. The idea
is to store data that has something in common or has similar characteristics. The
database server stores the data in each tablespace in data files with .dbf extensions.
• Segments are used to organize tablespace data within a tablespace. A segment stores
an individual database object like a table or index.
• Extents are contiguous units of storage, usually disk space, within a segment. Oracle
uses extents for performance reasons by storing data that needs to be retrieved in a
single disk I/O. An extent is made up of multiple data blocks
• Data Blocks are the smallest unit of Oracle database storage. Oracle 11g stores 8,192
bytes (8K) in one data block. A data block is comprised of multiple operating system
blocks. Depending on the operating system an operating system block can store 512 to
4K bytes. A data block contains header, directory and row data:
1.Block Header - operating system block address
2.Table Directory - identifies the database table for which the following data belongs
3.Row Directory - identifies the database rows for which the data belongs
4.Row Data - stores the actual row values