Exploring Oracle Database Administration

Oracle Architectural Components and Database Creation

Oracle Architectural Components and Database Creation
This chapter provides an overview of the Oracle architecture and talks about the various components that make an Oracle Instance. It also talks about the creation of database and various modes of starting and shutting down a database.

SCOPE
1.1Oracle Architecture and its main components 1.1.1System Global Area Overview 1.1.2Program Global Area (PGA) Overview 1.1.3Oracle Processes Overview 1.2Oracle Instance 1.3Managing an Oracle Instance 1.4Start up and shut down 1.4.1Starting up the database 1.4.2Starting up an instance

1.4.3Shutting down a database 1.5Alert Log File 1.6Setup Password File Authentication 1.7Oracle9i Installation Procedure 1.8Configure OMF 1.9 Prerequisites for database creation 1.9.1Planning for database creation 1.9.2Meeting Prerequisites 1.10 Create and manage Initialization parameter files 1.10.1Determine the global database name 1.10.2Specify Control Files 1.10.3Specify database block size 1.10.4Setting Initialization parameters that affect the size of SGA 1.10.5Specifying the Maximum Number of Processes 1.10.6Specifying a method of Undo Space Management 1.10.7Managing Initialization parameter files using a server parameter file 1.11 Creating a database manually 1.12 Create a database using Oracle Database Configuration Assistant 1.12.1Advantages of using Oracle Database Configuration Assistant: 1.12.2Creating a database 1.12.3Global Database name and Parameters 1.12.4Completing Database Creation 1.12.5Deleting a database 1.13Monitor the use of Diagnostic Files
© Copyright 2006, Tata Consultancy Services Limited (TCS). 1

Exploring Oracle Database Administration

Oracle Architectural Components and Database Creation

1.1Oracle Architecture and its main components
An Oracle Database is comprised of physical files, memory areas and processes. The distribution of these components varies depending on the database architecture chosen. The data in the database is stored in physical files (called data files) on a disk. As it is used that data is stored in the memory. Oracle uses memory areas to improve performance and to manage the sharing of data between users. The main memory area in the database is called the System Global Area (SGA). To read and write data between SGA and data files, Oracle uses a set of background processes that are shared by all users. The basic memory structures of Oracle include: System Global Area (SGA), which is shared by all server and background processes and holds the following: • • • • Database buffer cache Redo log buffer Shared pool Large pool (if configured)

Program Global Areas (PGA), which is private to each server and background process; there is one PGA for each process. The PGA holds the following: • • Stack areas Data areas

Fig. 1.1 – Oracle Memory Structure

1.1.1

System Global Area Overview
© Copyright 2006, Tata Consultancy Services Limited (TCS). 2

Exploring Oracle Database Administration

Oracle Architectural Components and Database Creation

A system global area (SGA) is a group of shared memory structures that contain data and control information for one Oracle database instance. If multiple users are concurrently connected to the same instance, then the data in the instance’s SGA is shared among the users. Consequently, the SGA is sometimes called the shared global area. An SGA and Oracle processes constitute an Oracle instance. Oracle automatically allocates memory for an SGA when you start an instance, and the operating system reclaims the memory when you shut down the instance. Each instance has its own SGA. The SGA is read/write. All users connected to a multiple-process database instance can read information contained within the instance’s SGA, and several processes write to the SGA during execution of Oracle. The SGA contains the following data structures: • Database buffer cache • Redo log buffer • Shared pool • Java pool • Large pool (optional) • Data dictionary cache • Other miscellaneous information Dynamic SGA Beginning with Oracle9i, Release 1 (9.0.1), Oracle can change its SGA configuration while the instance is running. With the dynamic SGA infrastructure, the sizes of the buffer cache, the shared pool, and the large pool can be changed without shutting down the instance. Dynamic SGA also allows Oracle to set, at run time, limits on how much virtual memory Oracle will use for the SGA. Oracle can start instances under configured and allow the instance to use more memory by growing the SGA components, up to a maximum of SGA_MAX_SIZE. If SGA_MAX_SIZE specified in INIT.ORA is less than the sum of all components specified or defaulted at initialisation time, then the setting of SGA_MAX_SIZE in INIT.ORA is ignored. The size of the SGA is determined by several initialisation parameters. The parameters that most affect SGA size are: DB_CACHE_SIZE: LOG_BUFFER: SHARED_POOL_SIZE: The size of the cache of standard blocks. The number of bytes allocated for the redo log buffer. The size in bytes of the area devoted to shared SQL and PL/SQL statements.
© Copyright 2006, Tata Consultancy Services Limited (TCS). 3

Exploring Oracle Database Administration

Oracle Architectural Components and Database Creation

LARGE_POOL_SIZE:

The size of the large pool; the default is 0.

1.1.1.1 Data Base Buffer Cache The database buffer cache is the portion of the SGA that holds copies of data blocks read from data files. All user processes concurrently connected to the instance share access to the database buffer cache. The database buffer cache and the shared SQL cache are logically segmented into multiple sets. This organization into multiple sets reduces contention on multiprocessor systems. Size of the Database Buffer Cache Oracle9i, Release 1 (9.0.1), supports multiple block size in a database. This is the default block size—the block size used for the system table space. You specify the standard block size by setting the initialisation parameter DB_BLOCK_SIZE. Legitimate values are from 2K to 32K. To specify the size of the standard block size cache, you set the initialisation parameter DB_CACHE_SIZE. Optionally, you can also set the size for two additional buffer pools, KEEP and RECYCLE, by setting DB_KEEP_CACHE_SIZE and DB_RECYCLE_CACHE_SIZE. These three parameters are independent of one another in Oracle9i, Release 1 (9.0.1). The sizes and numbers of non-standard block size buffers are specified by the following parameters: DB_2K_CACHE_SIZE DB_4K_CACHE_SIZE DB_8K_CACHE_SIZE DB_16K_CACHE_SIZE DB_32K_CACHE_SIZE Each parameter specifies the size of the cache for the corresponding block size. 1.1.1.2 Redo Log Buffer The redo log buffer is a circular buffer in the SGA that holds information about changes made to the database. This information is stored in redo entries. Redo entries contain the information necessary to reconstruct, or redo, changes made to the database by INSERT, UPDATE, DELETE, CREATE, ALTER, or DROP operations. Redo entries are used for database recovery, if necessary.

© Copyright 2006, Tata Consultancy Services Limited (TCS).

4

buffers for parallel execution messages. The background process LGWR writes the redo log buffer to the active online redo log file (or group of files) on disk. particularly if transactions are long or numerous. Shared SQL Areas A shared SQL area contains the parse tree and execution plan for a given SQL statement. The redo entries take up continuous. compiled form of a program unit. 5 . Oracle accesses the data © Copyright 2006. then a single. The default value of this parameter is 8M on 32-bit platforms and 64M on 64-bit platforms.1. shared area is used by all users. while each user maintains a separate copy of his or her private SQL area. Oracle allocates a private area to hold values specific to the session that executes the program unit. Tata Consultancy Services Limited (TCS). dictionary cache. The total size of the shared pool is determined by the initialisation parameter SHARED_POOL_SIZE. private SQL areas (in the case of a multiple transaction server). The default setting is four times the maximum data block size for the host operating system. PL/SQL Program Units and the Shared Pool Oracle processes PL/SQL program units (procedures. functions. If more than one user executes the same program unit. its structures.3 The Shared Pool The shared pool portion of the SGA contains three major areas: library cache. sequential space in the buffer. Increasing the value of this parameter increases the amount of memory reserved for the shared pool. and package variables (also known as package instantiation) and buffers for executing SQL. Dictionary Cache The data dictionary is a collection of database tables and views containing reference information about the database.Exploring Oracle Database Administration Oracle Architectural Components and Database Creation Redo entries are copied by Oracle server processes from the user’s memory space to the redo log buffer in the SGA. 1. PL/SQL procedures and packages. Oracle saves memory by using one shared SQL area for SQL statements executed multiple times. anonymous blocks. and its users.1. including local. and database triggers) much the same way it processes individual SQL statements. Oracle allocates a shared area to hold the parsed. The initialisation parameter LOG_BUFFER determines the size (in bytes) of the redo log buffer. global. Library Cache The library cache includes the shared SQL areas. holding values specific to his or her session. In general. packages. larger values reduce log file I/O. and control structures such as locks and library cache handles. and control structures. which often happens when many users execute the same application.

1.2 Program Global Area (PGA) Overview A program global area (PGA) is a memory region. and for parallel buffers is allocated in buffers of a few hundred kilobytes. also known as the row cache because it holds data as rows instead of buffers (which hold entire blocks of data). It is different from reserved space in the shared pool.4 Large Pool The database administrator can configure an optional memory area called the large pool to provide large memory allocations for: • Session memory for the shared server and the Oracle XA interface (used where transactions interact with more than one database) • I/O server processes • Oracle backup and restore operations • Parallel execution message buffers. which contains data and control information for a server process. The large pool is better able to satisfy such large memory requests than the shared pool. The large pool does not have an LRU list. One area is called the data dictionary cache. It is a nonshared memory created by Oracle when a server process is started. the memory for Oracle backup and restore operations.Exploring Oracle Database Administration Oracle Architectural Components and Database Creation dictionary frequently during SQL statement parsing. Oracle can use the shared pool primarily for caching shared SQL and avoid the performance overhead caused by shrinking the shared SQL cache.1. Oracle XA. 6 . if the initialisation parameter PARALLEL_ AUTOMATIC_TUNING is set to TRUE (otherwise. 1. Contents of PGA: Private SQL Area © Copyright 2006. for I/O server processes. Access to it is exclusive to that server process and is read and written only by Oracle code acting on behalf of it. The other area in memory to hold dictionary data is the library cache.1. The total PGA memory allocated by each server process attached to an Oracle instance is also referred to as the aggregated PGA memory allocated by the instance. In addition. The data dictionary is accessed so often by Oracle that two special locations in memory are designated to hold dictionary data. which uses the same LRU list as other memory allocated from the shared pool. This access is essential to the continuing operation of Oracle. 1. All Oracle user processes share these two caches for access to data dictionary information. these buffers are allocated to the shared pool) By allocating session memory from the large pool for shared server. Tata Consultancy Services Limited (TCS). or parallel query buffers.

The allocation and deallocation of private SQL areas depends largely on which application tool you are using. or handles to specific private SQL areas. Cursors and SQL Areas The application developer of an Oracle precompiler program or OCI program can explicitly open cursors.1. The management of private SQL areas is the responsibility of the user process. although the number of private SQL areas that a user process can allocate is always limited by the initialisation parameter OPEN_CURSORS.Exploring Oracle Database Administration Oracle Architectural Components and Database Creation A private SQL area contains data such as bind information and runtime memory structures. a user process always communicates with Oracle through a separate server process. Server processes (or the server portion of combined user/server processes) created on behalf of each user’s application can perform one or more of the following: • • • Parse and execute SQL statements issued through the application Read necessary data blocks from data files on disk into the shared database buffers of the SGA. The default value of this parameter is 50. when the application and Oracle operate on different machines. 7 . Each user that submits the same SQL statement has his/ her own private SQL area that uses a single shared SQL area. it is possible to combine the user process and corresponding server process into a single process to reduce system overhead. Server Processes Oracle creates server processes to handle the requests of user processes connected to the instance. It also describes the trace files and alert file. which record database events for the Oracle processes. many private SQL areas can be associated with the same-shared SQL area. © Copyright 2006. Each session that issues a SQL statement has a private SQL area. and use them as a named resource throughout the execution of the program. 1. Tata Consultancy Services Limited (TCS). In some situations when the application and Oracle operate on the same machine. if the blocks are not already present in the SGA Return results in such a way that the application can process the information Background Processes To maximize performance and accommodate many users. a multiprocess Oracle system uses some additional Oracle processes called background processes. Recursive cursors that Oracle issues implicitly for some SQL statements also use shared SQL areas. Thus. However.3 Oracle Processes Overview This section describes the two types of processes that execute the Oracle server code (server processes and background processes).

2 show how each background process interacts with the different parts of an Oracle database. © Copyright 2006. and the rest of this section describes each process. 8 . Tata Consultancy Services Limited (TCS).Exploring Oracle Database Administration Oracle Architectural Components and Database Creation An Oracle instance can have many background processes. background processes are created automatically when an instance is started. Figure 1. The background processes in an Oracle instance include the following: • Database Writer (DBW0 or DBWn) • Log Writer (LGWR) • Checkpoint (CKPT) • System Monitor (SMON) • Process Monitor (PMON) • Archiver (ARCn) • Recoverer (RECO) • Lock Manager Server (LMS) . not all are always present.Real Application Clusters only • Queue Monitor (QMNn) • Dispatcher (Dnnn) • Server (Snnn) On many operating systems.

1.1. 9 .Exploring Oracle Database Administration Oracle Architectural Components and Database Creation Fig 1. These additional DBWn processes are not useful on uniprocessor systems. Tata Consultancy Services Limited (TCS).3.1 Database Writer Process (DBWn) The database writer process (DBWn) writes the contents of buffers to data files.3. Although one database writer process (DBW0) is adequate for most systems. The DBWn processes are responsible for writing modified (dirty) buffers in the database buffer cache to disk. 1. you can configure additional processes (DBW1 through DBW9) to improve write performance if your system modifies data heavily.2 Log Writer Process (LGWR) © Copyright 2006.2 Showing background process interacting with different parts of oracle database 1.

LGWR writes: • A commit record when a user process commits a transaction • Redo log buffers 1. if necessary 1.3. PMON periodically checks the status of dispatcher and server processes. LGWR writes one contiguous portion of the buffer to disk. at instance startup.5 Process Monitor Process (PMON) The process monitor (PMON) performs process recovery when a user process fails. The statistic DBWR checkpoints displayed by the System_Statistics monitor in Oracle Enterprise Manager indicates the number of checkpoint requests completed. Oracle must update the headers of all data files to record the details of the checkpoint. Other processes can call SMON if they detect a need for SMON to wake up. the SMON process of one instance can perform instance recovery for a failed CPU or instance. The CKPT process does not write blocks to disk.1. LGWR normally writes fast enough to ensure that space is always available in the buffer for new entries. The redo log buffer is a circular buffer. if necessary. even when access to the redo log is heavy. DBWn always performs that work. SMON wakes up regularly to check whether it is needed. and restarts any that have died (but not any that Oracle has terminated intentionally).4 System Monitor Process (SMON) The system monitor process (SMON) performs crash recovery. This is done by the CKPT process. Every three seconds 2. When a DBWn process writes modified buffers to disk.1. releases locks. and removes the process ID from the list of active processes. If any dead transactions were skipped during crash and instance recovery because of fileread or offline errors.Exploring Oracle Database Administration Oracle Architectural Components and Database Creation The log writer process (LGWR) is responsible for redo log buffer management— writing the redo log buffer to a redo log file on disk. 1. 10 . SMON is also responsible for cleaning up temporary segments that are no longer in use and for coalescing contiguous free extents within dictionary-managed table spaces. LGWR writes all redo entries that have been copied into the buffer since the last time it wrote. SMON recovers them when the table space or file is brought back online.3. For example.1. When the redo log buffer is one-third full 3. Tata Consultancy Services Limited (TCS). 1. © Copyright 2006. it resets the status of the active transaction table.3 Checkpoint Process (CKPT) When a checkpoint occurs. When LGWR writes redo entries from the redo log buffer to a redo log file. With Oracle9i Real Application Clusters. server processes can then copy new entries over the entries in the redo log buffer that have been written to disk.3. PMON is responsible for cleaning up the database buffer cache and freeing resources that the user process was using.

the job queue processes try to execute the job at the next occurrence of the interval. RECO automatically tries to connect again after a timed interval. Given a start date and an interval. The coordinator process. 1. 2. The RECO process is present only if the instance permits distributed transactions and if the DISTRIBUTED_TRANSACTIONS parameter is greater than zero.0. Release 1 (9. The CJQ0 process dynamically spawns job queue slave processes (J000… J999) to execute the jobs. The resources used by the new processes are released when they are idle.1. This allows job queue clients to use more job queue processes when required. Tata Consultancy Services Limited (TCS). Beginning with Oracle9i. If this initialisation parameter is zero. The processes execute one job at a time. RECO waits an increasing amount of time (growing exponentially) before it attempts another connection. The job queue processes execute user jobs as they are assigned by the CJQ process. job queue processes are managed dynamically. named CJQ0.3. However. 3.3. New jobs selected are ordered by time. If the RECO process fails to connect with a remote server.7 Job Queue Processes Job queue processes are used for batch processing. 11 .1. removing from each database’s pending transaction table any rows that correspond to the resolved in-doubt transactions. Here’s what happens: 1. periodically selects jobs that need to be run from the system JOB$ table. They execute user jobs. The RECO process of a node automatically connects to other databases involved in an in-doubt distributed transaction. Like SMON.6 Recoverer Process (RECO) The recoverer process (RECO) is a background process used with the distributed database configuration that automatically resolves failures involving distributed transactions.1). RECO is not created during instance startup. 1. it automatically resolves all in-doubt transactions. When the RECO process re-establishes a connection between involved database servers. Dynamic job queue processes can execute a large number of jobs concurrently at a given interval. The job queue process executes one of the jobs that were selected by the CJ process for execution. PMON wakes up regularly to check whether it is needed and can be called if another process detects the need for it. © Copyright 2006.Exploring Oracle Database Administration Oracle Architectural Components and Database Creation PMON also registers information about the instance and dispatcher processes with the network listener. They can be viewed as a scheduler service that can be used to schedule jobs as PLSQL statements or procedures on an Oracle instance.

However. If there are no scheduled jobs for execution.9 Lock Manager Server Process (LMS) In Oracle9i Real Application Clusters. 12 . The ALERT file keeps a record of when LGWR starts a new ARCn process.8 Archiver Processes (ARCn) The archiver process (ARCn) copies online redo log files to a designated storage device after a log switch has occurred. Tata Consultancy Services Limited (TCS). 1. and automatic archiving is enabled.1. it polls for more jobs. An Oracle instance can have up to 10 ARCn processes (ARC0 to ARC9).3. it enters a sleep state. 1. The LGWR process starts a new ARCn process whenever the current number of ARCn processes is insufficient to handle the workload.1. After the process finishes execution of a single job. © Copyright 2006. a Lock Manager Server process (LMS) provides inter-instance resource management.Exploring Oracle Database Administration Oracle Architectural Components and Database Creation 4. clients should not assume that all job queue processes are available for job execution. it aborts after a preset interval.ora parameter JOB_QUEUE_PROCESSES represents the maximum number of job queue processes that can concurrently run on an instance. ARCn processes are present only when the database is in ARCHIVELOG mode. If the process does not find any new jobs.3. from which it wakes up at periodic intervals and polls for more jobs. The init.

This is called mounting the database. When a database is started on a database server (regardless of the type of computer). In clustered and massively parallel systems (MPP).3. which monitors the message queues. Oracle allocates a memory area called the System Global Area (SGA) and starts one or more Oracle processes. © Copyright 2006. Oracle9i Real Application Clusters enables multiple instances to mount a single database. The database is then ready to be opened. 13 .Exploring Oracle Database Administration Oracle Architectural Components and Database Creation 1.1.2Oracle Instance Introduction to an Oracle Instance Every running Oracle database is associated with an Oracle instance. each accessing its own physical database. These processes are different from other Oracle background processes in that process failure does not cause the instance to fail. Multiple instances can execute concurrently on the same computer. Oracle associates the instance with the specified database. Fig 1. Tata Consultancy Services Limited (TCS).10 Queue Monitor Processes (QMNn) The queue monitor process is an optional background process for Oracle Advanced Queuing. The memory and processes of an instance manage the associated database’s data efficiently and serve the one or multiple users of the database. This combination of the SGA and the Oracle processes is called an Oracle instance. which makes it accessible to authorized users.3 shows an Oracle Instance The Instance and the Database After starting an instance. 1. You can configure up to 10 queue monitor processes.

Set these parameters to particular values to initialise many of the memory and process settings of an Oracle instance. Security for database startup and shutdown is controlled through connections to Oracle with administrator privileges. which are called variable parameters Among other things. the database administrator can shut down the database so that it is closed.Exploring Oracle Database Administration Oracle Architectural Components and Database Creation Only the database administrator can start up an instance and open the database. When a database is closed. 1. 14 . users cannot access the information that it contains.3Managing an Oracle Instance Initialization Parameter Files To start an instance. filename2 # LOG_ARCHIVE_DEST = C:\DEST LOG_ARCHIVE_START = TRUE LOG_BUFFER = 64512 UNDO_MANAGEMENT = TRUE © Copyright 2006. Most initialisation parameters belong to one of the following groups: • Parameters that name things (such as files) • Parameters that set limits (such as maximums) • Parameters that affect capacity (such as the size of the SGA).ACME. Tata Consultancy Services Limited (TCS). the initialisation parameters tell Oracle: • • • • • The name of the database for which to start up an instance How much memory to use for memory structures in the SGA What to do with filled online redo log files The names and locations of the database’s control files The names of private rollback segments or undo table spaces in the database The following is an example of a parameter file DB_BLOCK_BUFFERS = 550 DB_NAME = ORAESD DB_DOMAIN = US. Normal users do not have control over the current status of an Oracle database. If a database is open.COM # LICENSE_MAX_USERS = 64 # CONTROL_FILES = filename1. Oracle must read an initialisation parameter file—a file containing a list of configuration parameters for that instance and database.

2. Using SQL*Plus to Start Up a Database You use the STARTUP command to start up a database instance.4Start up and shut down 1.ora init$ORACLE_SID. by using the PFILE clause of the STARTUP command. 1. 15 .4. To start an instance. Connect to Oracle as SYSDBA: CONNECT username/password AS SYSDBA Now you are connected to Oracle and ready to start up an instance of your database. the platform-specific default location (directory) for the server parameter file (or text initialisation parameter file) is: $ORACLE_HOME/dbs For Windows NT and Windows 2000 the location is: $ORACLE_HOME\database In the platform-specific default location. spfile$ORACLE_SID. Oracle locates your initialisation parameter file by examining filenames in the following order: 1. Note: For UNIX. Oracle reads the initialisation parameters from a server parameter file (SPFILE) in a platform-specific default location.1 Starting up the database These are the preliminary steps to be performed before attempting to start an instance of database using SQL*Plus.Exploring Oracle Database Administration Oracle Architectural Components and Database Creation 1. Tata Consultancy Services Limited (TCS).ora You can direct Oracle to read initialisation parameters from a traditional text initialisation parameter file. When you issue the STARTUP command with no PFILE clause. © Copyright 2006.ora spfile. 3. Oracle must read instance configuration parameters (the initialisation parameters) from either a server parameter file or a traditional text initialisation parameter file. Start SQL*Plus without connecting to the database: SQLPLUS /NOLOG 2.

ora 1.2. and then mount and open the database by using the STARTUP command by itself. but does not allow general access to the database. or in restricted mode.4.4. allowing access for database administrators only. Start an instance. This state allows for certain activities.1/dbs/inittest1. Tata Consultancy Services Limited (TCS). This does not allow access to the database and usually would be done only for database creation or the re-creation of control files Start the instance and mount the database. Total System Global Area Fixed Size Variable Size Database Buffers Redo Buffers Database mounted. Start the instance. read the initialisation parameters from the default server parameter file location. This can be done in unrestricted mode. and mount and open the database. 1.2 Starting up an instance You can start up an instance in these modes: • • • Start the instance without mounting a database. 16 .Exploring Oracle Database Administration Oracle Architectural Components and Database Creation For example: STARTUP PFILE = /home/oracle/product/9. but leave it closed.0. SQL> STARTUP ORACLE instance started. This mode allows any valid user to connect to the database and perform typical data access operations. and Mounting and Opening a Database Normal database operation means that an instance is started and the database is mounted and open. Database opened. SQL> 235693104 bytes 279600 bytes 167772160 bytes 67108864 bytes 532480 bytes © Copyright 2006.1 Starting an Instance. allowing access to all users.

2.2. Total System Global Area Fixed Size Variable Size Database Buffers Redo Buffers Database mounted. 17 . you must first connect as SYSOPER or SYSDBA. Total System Global Area 235693104 bytes Fixed Size 279600 bytes Variable Size 167772160 bytes Database Buffers 67108864 bytes Redo Buffers 532480 bytes SQL> 1.4. you do so only during database creation. Tata Consultancy Services Limited (TCS). • • • • Shutting down with Normal option Shutting down with Immediate option Shutting down with transactional option Shutting down with abort option © Copyright 2006.3 Shutting down a database To shut down a database and instance. There are various modes of shutting down a database. 235693104 bytes 279600 bytes 167772160 bytes 67108864 bytes 532480 bytes 1.Exploring Oracle Database Administration Oracle Architectural Components and Database Creation 1.2 Starting an Instance Without Mounting a Database You can start an instance without mounting a database. Typically. Use the STARTUP command with the NOMOUNT option: SQL> startup nomount ORACLE instance started.4.3 Starting an Instance and Mounting a Database Start an instance and mount the database. but leave it closed by using the STARTUP command with the MOUNT option: SQL> startup mount ORACLE instance started.4.

Oracle waits for all currently connected users to disconnect from the database.4. • • 1. Tata Consultancy Services Limited (TCS).3. 1.4. The next startup of the database will not require any instance recovery procedures. ORACLE instance shut down.3. SQL> Normal database shutdown proceeds with the following conditions: No new connections are allowed after the statement is issued. Before the database is shut down. The next startup of the database will not require any instance recovery procedures.4. use the SHUTDOWN command with the IMMEDIATE option: SHUTDOWN IMMEDIATE Immediate database shutdown proceeds with the following conditions: • • • No new connections are allowed Any uncommitted transactions are rolled back.1 Shutting Down with the NORMAL Option To shut down a database in normal situations.3 Shutting down with Transactional option To perform a planned shutdown of an instance while allowing active transactions to complete first.Exploring Oracle Database Administration Oracle Architectural Components and Database Creation 1.3. use the SHUTDOWN command with the TRANSACTIONAL option: SHUTDOWN TRANSACTIONAL © Copyright 2006. Oracle implicitly rolls back active transactions and disconnects all connected users. Database closed. use the SHUTDOWN command with the NORMAL option: SQL> shutdown normal. Database dismounted.2 Shutting Down with the IMMEDIATE Option The immediate database shutdown can be used in the following situations: • • • To initiate an automated and unattended backup When a power shutdown is going to occur soon When the database or one of its applications is functioning irregularly and you cannot contact users to ask them to log off or they are unable to log off To shut down a database immediately. 18 .

and DROP statements and STARTUP.Exploring Oracle Database Administration Oracle Architectural Components and Database Creation Transactional database shutdown proceeds with the following conditions: • • • No new connections are allowed After all transactions have completed.4. such as CREATE. • Uncommitted transactions are not rolled back. SHUTDOWN. is a special trace file. after the statement is issued. or alert log. The alert file of a database is a chronological log of messages and errors. The alert file. • 1. nor are new transactions allowed to be started. and deadlock errors (ORA-60) that occur • Administrative operations.4 Shutting down with ABORT Option When you must do a database shutdown by aborting transactions and user connections. • Current client SQL statements being processed by Oracle are immediately terminated. • Oracle does not wait for users currently connected to the database to disconnect. Oracle implicitly disconnects all connected users. Some of the information written to a trace file is intended for the database administrator. Trace file information is also used to tune applications and instances. ALTER. while other information is for Oracle Support Services. At this point. 19 . The next startup of the database will require instance recovery procedures. it dumps information about the error to its trace file.3. Tata Consultancy Services Limited (TCS).5Alert Log File Each server and background process can write to an associated trace file. issue the SHUTDOWN command with the ABORT option: SHUTDOWN ABORT An aborted database shutdown proceeds with the following conditions: No new connections are allowed. and ARCHIVELOG statements • Several messages and errors relating to the functions of shared server and dispatcher processes • Errors occurring during the automatic refresh of a materialized view • The values of all initialisation parameters at the time the database and instance Start Initialization parameters controlling the location and size of trace files are: • © Copyright 2006. 1. the instance shuts down just as it would when a SHUTDOWN IMMEDIATE statement is submitted. When a process detects an internal error. block corruption errors (ORA-1578). which includes the following: All internal errors (ORA-600). any client still connected to the instance is disconnected.

There are no spaces around the equal-to (=) character. For example.5. entries .pwd PASSWORD=secret ENTRIES=30 file named © Copyright 2006. password . • • • • Using ORAPWD Setting REMOTE_LOGIN_PASSWORDFILE Adding users to Password file Maintaining a password file 1.1 Using ORAPWD: Syntax for ORAPWD orapwd Usage: orapwd file=<fname> password=<password> entries=<users> where file .pwd that allows up to 30 privileged users with different passwords: ORAPWD FILE=acct. 20 .maximum number of distinct DBAs and OPERs (opt).1 Specifying the location of Trace and Alert Files All trace files for background processes and the alert file are written to the destination directory specified by the initialisation parameter BACKGROUND_DUMP_DEST. This section covers these topics.6. the following command creates a password acct. 1. The names of trace files are operating system specific.Exploring Oracle Database Administration Oracle Architectural Components and Database Creation • • • BACKGROUND_DUMP_DEST USER_DUMP_DEST MAX_DUMP_FILE_SIZE 1. All trace files for server processes are written to the destination directory specified by the initialisation parameter USER_DUMP_DEST.6Setup Password File Authentication Password file can be created by a utility called ORAPWD. but each file usually includes the name of the process writing the file (such as LGWR and RECO).password for SYS (mand).name of password file (mand). Tata Consultancy Services Limited (TCS).

All users needing SYSDBA or SYSOPER system privileges must connect using the same name. you must also set the initialisation parameter Remote_Login_Passwordfile to an appropriate value.2 Setting Remote_Login_PasswordFile Apart from creating the Password file . The contents of this file are encrypted. Entries: This parameter specifies the number of entries that you require the password file to accept. and password. Only an EXCLUSIVE file can contain the names of users other than SYS. 21 . This parameter is mandatory. the only user recognized by a SHARED password file is SYS. However. both the password stored in the data dictionary and the password stored in the password file are updated.Exploring Oracle Database Administration Oracle Architectural Components and Database Creation Following are the description of parameters in ORAPWD utility: File: This parameter sets the name of the password file being created. • Shared: A SHARED password file can be used by multiple databases. You cannot add users to a SHARED password file. Tata Consultancy Services Limited (TCS).6. 1. • © Copyright 2006. SYS. NONE is the default value for this parameter. This parameter is mandatory. If you issue the ALTER USER statement to change the password for SYS after connecting to the database. and the file cannot be read directly. Using an EXCLUSIVE password file allows you to grant SYSDBA and SYSOPER system privileges to individual users and have them connect as themselves. The values are the following: None: Setting this parameter to NONE causes Oracle to behave as if the password file does not exist. Password: This parameter sets the password for user SYS. This number corresponds to the number of distinct users allowed to connect to the database as SYSDBA or SYSOPER. You must specify the full path name for the file. • Exclusive: An EXCLUSIVE password file can be used with only one database. This option is useful if you have a single DBA administering multiple databases.

Oracle compares the value of this © Copyright 2006.6.4. To replace a password file: Shutdown the database Delete the existing password file Create a new password file using ORAPWD utility with sufficient ENTRIES parameter which u think might be used. When you first create a password file. you must create a larger password file and regrant the privileges to the users.6.2 Remove the password file If you determine that you no longer require a password file to authenticate users. • • • 1. Oracle retrieves the value of this parameter from the parameter file stored on your client machine.6. 1. Connect with SYSDBA privilege as shown in example Connect sys/password as sysdba 4.4.4.1 Expanding the number of Password file users: If you receive the file full error (ORA-1996) when you try to grant SYSDBA or SYSOPER system privileges to a user. 22 . Set the Remote_Login_Passwordfile parameter to EXCLUSIVE 3.6. only those users who can be authenticated by the operating system can perform database administration operations. Create users as necessary. After you remove this file. 1. or mount and open an existing database. When you start up an instance. Start up the instance and create the database if necessary.3 Adding Users to Password File: 1. 5. Tata Consultancy Services Limited (TCS).4 Maintaining a Password file: This section describes how to: • • • Expand the number of password file users if the password file becomes full Remove the password file Avoid changing the state of the password file 1. When you mount the database.Exploring Oracle Database Administration Oracle Architectural Components and Database Creation 1. Create a password file using ORAPWD utility following the syntax 2. its default state is SHARED. You can change the state of the password file by setting the initialisation parameter REMOTE_LOGIN_PASSWORDFILE.3 Changing the state of password file: The password file state is stored in the password file. Grant SYSDBA or SYSOPER privileges.6. you can delete the password file and reset the REMOTE_LOGIN_PASSWORDFILE initialisation parameter to NONE.

Exploring Oracle Database Administration Oracle Architectural Components and Database Creation parameter to the value stored in the password file. the Oracle Enterprise Manager framework of management tools. and Intelligent Agent. Enterprise Edition: If you select this type.1 Oracle9i has these components.1. It also installs those products most commonly used in data warehousing and transaction processing environments. licensable Oracle Options.7. including Console. Oracle overwrites the value stored in the file. Tata Consultancy Services Limited (TCS). database environment tools. Standard Edition. Management Server. Personal Edition. • • • Oracle9i Database Oracle9i Client Oracle9i Management and Integration 1. and online documentation. or Custom.7. Oracle Universal Installer provides the following capabilities: • • • • • • • Component and suite installations Web-based installations National language and globalisation support Distributed installation support Unattended "silent" installations using response files Uninstallation of installed components Multiple Oracle homes support Oracle9i products for Installation: 1. If the values do not match. Oracle Universal Installer installs a preconfigured seed database. networking services.1 Oracle9i database: The Oracle9i Database is an object-oriented relational database management system. Oracle utilities.7Oracle9i Installation Procedure Oracle Universal Installer Overview Oracle Universal Installer is a Java-based graphical user interface (GUI) tool that enables you to install Oracle components from your CD-ROM. 23 . which consists of an Oracle database and an Oracle instance. 1. There are four installation types: Enterprise Edition. © Copyright 2006.

Oracle Universal Installer prompts you to select individual components to install from the components available with Administrator and Runtime. and Oracle utilities.1. Oracle Integration Server. Tata Consultancy Services Limited (TCS). There are four Management and Integration installation types: Oracle Management Server.1. There are three Client installation types: Administrator. Personal Edition: If you select this type. but supports only a single user development and deployment environment that requires full compatibility with Enterprise Edition and Standard Edition. and Custom. Oracle Universal Installer installs a preconfigured seed database. Standard Edition. including enterprise management tools. utilities. Oracle Universal Installer prompts you to select individual components to install from the components available with Enterprise Edition. Note that Oracle Management Server and Intelligent Agent are not supported on Windows 98. © Copyright 2006. Oracle Enterprise Manager framework of management tools.Exploring Oracle Database Administration Oracle Architectural Components and Database Creation Standard Edition: If you select this type. and Personal Edition installations. Oracle Internet Directory. and Custom. including Console.7. Oracle Universal Installer installs the Oracle Enterprise Manager Console. Oracle Universal Installer installs networking services and support files. networking services. Runtime: If you select this type. 24 . Administrator: If you select this type. Oracle Integration Server is a suite of software that provides Internet and intranet tools to integrate applications within and across organizations. Personal Edition is the only Oracle9i Database installation type that is supported on Windows 98. Runtime.7. Custom: If you select this type. and Intelligent Agent. 1. Custom: If you select this type.2 Oracle9i Client The Oracle9i Client is a front-end database application that connects to the database through one or more application servers. Management Server. It enables distributed control between clients and managed nodes. Oracle Internet Directory is an database-based LDAP v3 directory server. and basic client software. 1. networking services. Oracle Universal Installer installs the same software as the Enterprise Edition installation type.3 Oracle9i Management and Integration Oracle Management Server is a central processing and distribution system for management tasks.

Oracle Universal Installer installs XML-enabled components that integrate enterprise applications. and the Oracle Internet Directory database schema. and Oracle Integration Server. a workflow engine. • Custom: If you select this type. Oracle Universal Installer installs a Lightweight Directory Access Protocol (LDAP)-enabled Oracle Internet Directory Server. where n specifies a multiplexed copy of the online redo log or control file. and advanced queuing. Components include Oracle9i JVM. In addition. You can specify up to five multiplexed copies. DB_CREATE_ONLINE_LOG_DEST_n: Defines the location of the default file system directory for online redo log files and control file creation when no file specification is given in the creation operation. Oracle Internet Directory. © Copyright 2006. • 1. Oracle Universal Installer installs basic client software. Oracle Universal Installer installs the Oracle Management Server. LDAP-enabled client tools. Also used as the default file system directory for online redo log and control files if DB_ CREATE_ONLINE_LOG_DEST_ n is not specified. • Oracle Internet Directory: If you select this type. • Oracle Integration Server: If you select this type. Include the DB_CREATE_FILE_DEST initialisation parameter in your initialisation parameter file to identify the default location for the database server to create: • • • • Data files Tempfiles Online redo log files Control files as the default The following example sets /u01/oradata/payroll directory to use when creating Oracle-managed files. Tata Consultancy Services Limited (TCS). which processes all system management tasks from the Enterprise Manager console and administers the distribution of these tasks to Intelligent Agents on managed nodes across the enterprise. The following initialisation parameters allow the database server to use the Oracle managed files feature: DB_CREATE_FILE_DEST: Defines the location of the default file system directory where Oracle creates data files or tempfiles when no file specification is given in the creation operation.8Configure OMF Oracle managed files simplifies the administration of an Oracle Database. You can use this initialisation parameter multiple times. Oracle Universal Installer prompts you to select individual components to install from the components available with Oracle Management Server.Exploring Oracle Database Administration Oracle Architectural Components and Database Creation Oracle Management Server: If you select this type. 25 .

9. file by multiplexing. and to manage the online and archived redo logs.1 • Plan the database tables and indexes and estimate the amount of space they will require. Create the global database name by setting both the DB_ NAME and DB_DOMAIN initialisation parameters. Plan the layout of the underlying operating system files.9 Prerequisites for database creation The following topics are to be looked into for database creation • • Planning for data base creation Meeting certain prerequisites Planning for database creation 1. Consider using Oracle Managed Files feature to create and manage operating systems files. It is important to protect the control. to choose the appropriate backup mode. Select the global database name. • • • • • • • © Copyright 2006. This is specified at database creation by the DB_BLOCK_SIZE initialisation parameter and cannot be changed after the database is created. 26 . Use an undo table space to manage your undo records.Exploring Oracle Database Administration Oracle Architectural Components and Database Creation DB_CREATE_FILE_DEST = '/u01/oradata/payroll' Setting the DB_CREATE_ONLINE_LOG_DEST_n initialisation parameter in the initialisation parameter file to identify the default location for the database server to create: • • Online Redo log files Control Files DB_CREATE_ONLINE_LOG_DEST_1 = ‘/u02/oradata/payroll’ DB_CREATE_ONLINE_LOG_DEST_2 = ‘/u02/oradata/payroll’ 1. Proper distribution of files can improve database performance dramatically by distributing the I/O for accessing the files. Tata Consultancy Services Limited (TCS). Select the data base character set Select the standard database block size. which is the name and location of the database within the network structure. Develop a backup and recovery strategy to protect the database from failure.

us.Exploring Oracle Database Administration • Oracle Architectural Components and Database Creation Get Familiar with the options of starting and shutting down an instance and mounting and opening a database.acme.10.2 • • • The desired Oracle Software has to be installed. Meeting Prerequisites 1.9.acme.2 Specify Control Files © Copyright 2006.com. During database creation. The combination of the settings for these two parameters must form a database name that is unique within a network. edit the parameters of the new parameter file as follows: DB_NAME = test DB_DOMAIN = us.1 Determine the global database name DB_DOMAIN parameter indicates the domain (logical location) within a network structure. There should be sufficient memory available to start up the Oracle Instance There should be sufficient disk storage space available on the computer that executes Oracle. the name provided for DB_NAME is recorded in the data files. If during database instance startup the value of the DB_NAME parameter (in the parameter file) and the database name in the control file are not the same.10. and control file of the database. For example.com DB_NAME must be set to a text string of no more than eight characters.10 Create and manage Initialization parameter files The following are the initialisation parameters one has to look into before creating a database: • • • • • • • Determine the global database name Specify control files Specify database block sizes Setting Initialization Parameters that affect the size of SGA Specify the maximum number of processes Specify the method of undo space management Setting License Parameters 1. This is typically the name of the organization that owns the database. 27 . redo log files. DB_DOMAIN is a text string that specifies the network domain where the database is created. to create a database with a global database name of test. Tata Consultancy Services Limited (TCS). the database does not start. 1. 1.

Tata Consultancy Services Limited (TCS). © Copyright 2006. 28 . When you execute the CREATE DATABASE statement.Exploring Oracle Database Administration Oracle Architectural Components and Database Creation CONTROL_FILES initialisation parameter has to be included in your new parameter file and set its value to a list of control filenames to use for the new database. the control files listed in the CONTROL_ FILES parameter will be created.

Typically DB_BLOCK_SIZE is set to either 4K or 8K The block size cannot be changed after database creation.3 Specify database block size The DB_BLOCK_SIZE initialisation parameter specifies the standard block size for the database.4 Setting Initialization parameters that affect the size of SGA DB_CACHE_SIZE Initialization Parameter The DB_CACHE_SIZE initialisation parameter replaces the DB_BLOCK_BUFFERS initialisation parameter that was used in previous releases. Tata Consultancy Services Limited (TCS). DB_ nK_CACHE_SIZE Initialization Parameters The sizes and numbers of non-standard block size buffers are specified by the following initialisation parameters: • • • • DB_2K_CACHE_SIZE DB_4K_CACHE_SIZE DB_8K_CACHE_SIZE DB_16K_CACHE_SIZE Adjusting the Size of the Shared Pool The SHARED_POOL_SIZE initialisation parameter is a dynamic parameter (in previous releases it was not dynamic) that allows you to specify or adjust the size of the shared pool component of the SGA.10. if your operating system’s block size is 2K (2048 bytes). Oracle selects an appropriate default value. 29 . Adjusting the Size of the Large Pool The LARGE_POOL_SIZE initialisation parameter is a dynamic parameter (in previous releases it was not dynamic) that allows you to specify or adjust the size of the large pool component of the SGA. except by re-creating the database. make the database block size a multiple of the operating system’s block size.10. the following setting for the DB_BLOCK_SIZE initialisation parameter is valid: DB_BLOCK_SIZE=4096 1. Limiting the size of the SGA: © Copyright 2006. This block size is used in creation of SYSTEM table space and by default in other table spaces. The DB_CACHE_SIZE parameter specifies the size of the cache of standard block size buffers. Oracle selects an appropriate default value. For example. where DB_ BLOCK_SIZE specifies the standard block size. If a database’s block size is different from the operating system block size.Exploring Oracle Database Administration Oracle Architectural Components and Database Creation 1.

but only to the extent that the sum of these sizes and the sizes of the other components of the SGA (fixed SGA. or rollback segment undo mode. UNDO_TABLESPACE Initialization Parameter When the instance starts up in automatic undo management mode.10. A default undo table space named SYS_UNDOTBS is automatically created when you execute a CREATE DATABASE statement and the UNDO_MANAGEMENT initialisation parameter is set to AUTO. For example. 30 . it selects the first available undo table space in the instance for storing undo. You can dynamically alter the initialisation parameters affecting the size of the buffer caches. Setting License parameters: To set the maximum number of concurrent sessions for an instance set the initialisation parameter LICENSE_MAX_SESSIONS in the initialisation parameter file that starts the instance: © Copyright 2006. Tata Consultancy Services Limited (TCS). SGA_MAX_SIZE >= DB_CACHE_SIZE + SHARED_POOL_SIZE + LARGE_POOL_SIZE + FIXED SGA + VARIABLE SGA + SIZE OF REDO LOG BUFFERS 1. where undo is stored in rollback segments.5 Specifying the Maximum Number of Processes The PROCESSES initialisation parameter determines the maximum number of operating system processes that can be connected to Oracle concurrently. and redo log buffers) does not exceed the value specified by SGA_MAX_SIZE. The value of this parameter must be 6 or greater (5 for the background processes plus 1 for each user process). This is the undo table space that Oracle will normally select whenever you start up the database. if you plan to have 50 concurrent users. A value of AUTO enables automatic undo management mode.10. 1. shared pool. set this parameter to at least 55. and large pool.6 Specifying a method of Undo Space Management Undo Management Initialization parameter determines whether an instance will start up in automatic undo management mode where undo is stored in an undo table space. variable SGA.Exploring Oracle Database Administration Oracle Architectural Components and Database Creation The SGA_MAX_SIZE initialisation parameter specifies the maximum size of the System Global Area for the lifetime of the instance. MANUAL enables rollback segment undo mode.

Exploring Oracle Database Administration Oracle Architectural Components and Database Creation LICENSE_MAX_SESSIONS = 80 To limit the number of users created in a database. % export ORACLE_SID=mynewdb environment The value of DB_NAME initialisation parameter should match the SID setting. Tata Consultancy Services Limited (TCS). Step 2: Establish the database administrator authentication method To create a database one should have appropriate system privileges Step 3: Create the initialisation parameter file Have a look at the sample initialisation parameter file and edit it accordingly.ora' FROM SPFILE='/u01/oracle/dbs/test_spfile.11 Creating a database manually Step 1: Decide on the instance identifier Decide on a unique Oracle System Identifier and set the ORACLE_SID variable accordingly.ora'. it is Overwritten with the new information. 31 . If a server parameter file of the same name already exists on the server.ora' FROM PFILE='/u01/oracle/dbs/test_init. set the LICENSE_MAX_USERS initialisation parameter in the database’s initialisation parameter file.10. as shown in the following example: LICENSE_MAX_USERS = 200 1. Store the initialisation parameter file in the Oracle’s default location. Exporting the server parameter file: The following example creates a text initialisation parameter file from a server parameter file where the names of the files are specified: CREATE PFILE='/u01/oracle/dbs/test_init. © Copyright 2006.ora'.7 Managing Initialization parameter files using a server parameter file Creating a server parameter file: CREATE SPFILE='/u01/oracle/dbs/test_spfile. 1.

aurora. (PROTOCOL=TCP) © Copyright 2006.1/dbs/initmynewdb. "/home1/oracle9i/mynewdb/control/control03.ora Default Location $ORACLE_HOME/dbs $ORACLE_HOME/database The initialisation parameter file initmynewdb.SGiopServer)" DISPATCHERS="(PROTOCOL=TCP)(SER=MODOSE)".0.1 Default parameter file locations Oracle Architectural Components and Database Creation Platform Unix NT Default Name Init$ORACLE_SID.server.Exploring Oracle Database Administration Table 1.ctl") # Archive LOG_ARCHIVE_DEST_1='LOCATION=/home1/oracle9i/mynewdb/archive' LOG_ARCHIVE_FORMAT=%t_%s.server.ctl".SGiopServer)".ora Init$ORACLE_SID.1: Sample Initialization parameter file #Cache and I/O DB_BLOCK_SIZE =4096 DB_CACHE_SIZE=20971520 # Cursors and Library Cache CURSOR_SHARING=SIMILAR OPEN_CURSORS=300 # Diagnostics and Statistics BACKGROUND_DUMP_DEST=/home1/oracle9i/mynewdb/ bdump CORE_DUMP_DEST=/home1/oracle9i /mynewdb/cdump TIMED_STATISTICS=TRUE USER_DUMP_DEST=/home1/oracle9i/mynewdb/udump # Control File configuration CONTROL_FILES=("/home1/oracle9i/mynewdb/control/control01. "(PROTOCOL=TCP)(PRE=oracle.dbf LOG_ARCHIVE_START=TRUE # Shared Server # Uncomment and use first DISPATCHES parameter below when your listener is # configured for SSL # (listener.ctl".ora and sqlnet.aurora. Tata Consultancy Services Limited (TCS).ora Step3.ora) # DISPATCHERS = "(PROTOCOL=TCPS)(SER=MODOSE)".ora is stored in the following location: /home/oracle/product/9. "/home1/oracle9i/mynewdb/control/control02. 32 . # "(PROTOCOL=TCPS)(PRE=oracle.

Replication and Snapshot DB_DOMAIN=til.Exploring Oracle Database Administration Oracle Architectural Components and Database Creation # Miscellaneous COMPATIBLE=9.0 DB_NAME=mynewdb # Distributed. $ SQLPLUS /nolog CONNECT SYS /MANAGER AS SYSDBA [oracle9i@esdlnx dbs]$ sqlplus /nolog SQL*Plus: Release 9. 33 .0.1.Production on Tue Oct 16 16:13:26 2001 (c) Copyright 2001 Oracle Corporation.0 . Hash Joins. Tata Consultancy Services Limited (TCS).0. Bitmap Indexes SORT_AREA_SIZE=524288 # System Managed Undo and Rollback Segments UNDO_MANAGEMENT=AUTO UNDO_TABLESPACE=undotbs Step4: Connect to the instance Start SQL*Plus and connect to your Oracle instance AS SYSDBA.com REMOTE_LOGIN_PASSWORDFILE=EXCLUSIVE # Network Registration INSTANCE_NAME=mynewdb # Pools JAVA_POOL_SIZE=31457280 LARGE_POOL_SIZE=1048576 SHARED_POOL_SIZE=52428800 # Processes and Sessions PROCESSES=150 # Redo Log and Recovery FAST_START_MTTR_TARGET=300 # Resource Manager RESOURCE_MANAGER_PLAN=SYSTEM_PLAN # Sort. © Copyright 2006. All rights reserved.0.

log') SIZE 100M. • Creates the SYSTEM table space and the SYSTEM rollback segment • Creates the data dictionary • Sets the character set that stores data in the database • Sets the database time zone • Mounts and opens the database for use The following statement creates database mynewdb: CREATE DATABASE mynewdb MAXINSTANCES 1 MAXLOGHISTORY 1 MAXLOGFILES 5 MAXLOGMEMBERS 5 MAXDATAFILES 100 DATAFILE '/home1/oracle9i/mynewdb/system01.dbf' SIZE 325M REUSE UNDO TABLESPACE undotbs DATAFILE '/home1/oracle9i/mynewdb/undotbs01. Only SGA is created and background processes are started in preparation for the creation of new database. SQL> Step5: Start the Instance Start the instance without mounting the database. Step6: Issue the Create database statement To create new database use CREATE DATABASE statement.log') SIZE 100M. This is done only during database creation or while performing maintenance operations. This statement does the following: • Creates the data files for the database • Creates the control files for the database • Creates the redo log files for the database and establishes the ARCHIVELOG mode.log') SIZE 100M. Use the Startup command without NOMOUNT option STARTUP NOMOUNT At this point. Tata Consultancy Services Limited (TCS).Exploring Oracle Database Administration Oracle Architectural Components and Database Creation SQL> connect sys/manage as sysdba Connected. only instance is created and there is no database. 34 .dbf' SIZE 200M REUSE AUTOEXTEND ON NEXT 5120K MAXSIZE UNLIMITED DEFAULT TEMPORARY TABLESPACE tempts1 TEMPFILE '/home1/oracle9i/mynewdb/temps1.dbf' SIZE 50M REUSE AUTOEXTEND ON NEXT 100K MAXSIZE UNLIMITED CHARACTER SET US7ASCII NATIONAL CHARACTER SET AL16UTF16 LOGFILE GROUP 1 ('/home1/oracle9i/mynewdb/redo01. GROUP 3 ('/home1/oracle9i/mynewdb/redo03. A database is created with the following characteristics: • The database is named mynewdb © Copyright 2006. GROUP 2 ('/home1/oracle9i/mynewdb/redo02.

or NVARCHAR2. The UNDO TABLE SPACE clause creates and names an undo table space to be used for undo records for this database. If the file already exists. Tata Consultancy Services Limited (TCS). The US7ASCII character set is used to store data in this database. As ARCHIVELOG clause is not specified in this CREATE DATABASE statement. and MAXLOGMEMBERS define limits for the redo log. the default database time zone is the operating system time zone. MAXLOGFILES. If omitted (as it is in this case). you need to create additional files and table spaces for users.dbf is created as specified by the DATAFILE clause. -. MAXLOGHISTORY.Create a table space for indexes.Exploring Oracle Database Administration • • • • Oracle Architectural Components and Database Creation • • • • • • • • Three control files are created as specified by CONTROL_FILES initialisation parameter MAXINSTANCES specified that only one instance can have this database mounted and open. separate from user table space CREATE TABLESPACE indx LOGGING DATAFILE '/home1/oracle9i/mynewdb/indx01. NCLOB. it is overwritten. redo log files will not initially be archived. You set the database’s default time zone by specifying the SET TIME_ZONE clause of the CREATE DATABASE statement. The following sample script creates some additional table spaces: CONNECT SYS/ password AS SYSDBA -. The new database has three online redo log files as specified in the LOGFILE clause. The default database time zone is the same as the operating system’s time zone. The AL16UTF16 character set is specified as the NATIONAL CHARACRTER SET used to store data in columns of specifically defined as NCHAR. Step7: Create Additional table spaces To make the database functional.dbf' SIZE 25M REUSE AUTOEXTEND ON NEXT 1280K MAXSIZE UNLIMITED EXTENT MANAGEMENT LOCAL. consisting of the operating system file /home1/oracle9i/mynewdb/system01. The DEFAULT_TEMPORARY_TABLESPACE clause creates a temporary table space. © Copyright 2006.dbf' SIZE 25M REUSE AUTOEXTEND ON NEXT 1280K MAXSIZE UNLIMITED EXTENT MANAGEMENT LOCAL.create a user table space to be assigned as the default table space for users CREATE TABLESPACE users LOGGING DATAFILE '/home1/oracle9i/mynewdb/users01. 35 . The SYSTEM table space. MAXDATAFILES specifies the maximum number of data files that can be open in the database.

Tata Consultancy Services Limited (TCS).1/rdbms/admin/catalog.SQL Creates the views of the data dictionary tables. and public synonyms for many of the views. CATPROC. and PL/SQL packages: CONNECT SYS/ password AS SYSDBA @/home/oracle/product/9.1/rdbms/admin/catproc. the dynamic Performance views. @/home/oracle/product/9.ora' FROM PFILE='/home/oracle/product/9.1/initmynewdb. © Copyright 2006.0.Create the server parameter file CREATE SPFILE=' /home/oracle/product/9.1/spfilemynewdb. synonyms.Exploring Oracle Database Administration Oracle Architectural Components and Database Creation Step8: Run scripts to create Data Dictionary Views: Run the scripts necessary to build views. EXIT CATALOG. Step9: Create Server parameter file: CONNECT SYS/ password AS SYSDBA -. SHUTDOWN This time you will start up using the server parameter file CONNECT SYS/ password AS SYSDBA STARTUP Step10: Back up the database Take the back up of the database.0.0. Grants PUBLIC access to the synonyms.0.sql.ora'.sql. 36 .SQL Runs all scripts required for or used with PL/SQL.

whereby database files and administrative files. you can choose either to include data files or not. to simplify the creation of a database. you will be able to save the database creation information as a template or script. • 1. complex queries that process large volumes of data.Exploring Oracle Database Administration Oracle Architectural Components and Database Creation 1.12. and recoverability are key issues. Availability. 37 . 1. including initialisation files. © Copyright 2006.12 Create a database using Oracle Database Configuration Assistant The Oracle Database Configuration Assistant (DBCA) is a graphical user interface (GUI) tool that interacts with the Oracle Universal Installer. follow standard naming and placement practices. You can run the script later to create a new database.2 Creating a database A database can be created from predefined templates provided by Oracle or from templates that you or others have created. accuracy. concurrence. speed. Response time. or it can be used to create or add instances in an Oracle Real Application Clusters environment.1 Advantages of using Oracle Database Configuration Assistant: Its wizards guide you through a selection of options providing an easy means of creating and tailoring your database. • It builds efficient and effective databases that take advantage of Oracle’s new features. and availability are key issues. If you select a template with data files. or can be used Standalone. New Database: This template allows you maximum flexibility in defining a database. Tata Consultancy Services Limited (TCS). Oracle provides templates for the following options: DSS: Users perform numerous. When you select a template. Using Oracle Database Configuration Assistant you can add or delete a database.12. • It uses Optimal Flexible Architecture (OFA). OLTP: Many concurrent users performing numerous transactions requiring rapid access to data. The Oracle Database Configuration Assistant can be used to create single instance databases.

Regardless of the current value of the SQL_TRACE initialisation parameter. Trace files are written on behalf of server processes whenever internal errors occur. specify database options to include. trace files can be generated for server processes at user request. it is possible.12. and ultimately you can specify initialisation parameter. you delete the database instance and its control file(s).3 Global Database name and Parameters You are guided thorough a series of pages that allow you to further define your database or to accept default parameter values and file locations as recommended by Oracle. to control the amount and type of trace information that is produced. redo log files. and data files. Optionally. In the case of the ARCn background process. Tata Consultancy Services Limited (TCS). When you do so. the percentage of physical memory reserved for Oracle.12. Typical: This creates a database with minimal user input. 1. instead.5 Deleting a database The Oracle Database Configuration Assistant enables you to delete a database.Exploring Oracle Database Administration Oracle Architectural Components and Database Creation 1. you specify the maximum number of concurrent users. Custom: Custom allows you to specify initialisation parameter values that affect the size of the System Global Area (SGA).13 Monitor the use of Diagnostic Files Trace Files: Background processes always write to a trace file when appropriate. Multipurpose or Data Warehousing). each session can enable or © Copyright 2006. Very experienced database administrators who have specific tuning needs can use it 1. 1. The initialisation parameter file is not deleted. You do not specify specific initialisation parameter values. and a database type (OLTP.12. through an initialisation parameter. 38 . Additionally. determine mode (dedicated server of shared server).4 Completing Database Creation After you have completed the specification of the parameters that define your database you can: • • • Create the database Save the description as database template Generate database creation scripts. You provide a global database name. setting the initialisation parameter SQL_TRACE = TRUE causes the SQL trace facility to generate performance statistics for the processing of all SQL statements for an instance and write them to the USER_DUMP_DEST directory.

The DBMS_SESSION and DBMS_SYSTEM packages can also be used to control SQL tracing for a session. This example enables the SQL trace facility for a specific session: ALTER SESSION SET SQL_TRACE TRUE. Tata Consultancy Services Limited (TCS). © Copyright 2006. 39 .Exploring Oracle Database Administration Oracle Architectural Components and Database Creation disable trace logging on behalf of the associated server process by using the SQL statement ALTER SESSION SET SQL_TRACE.

 A system global area (SGA) is a group of shared memory structures that contain data and control information for one Oracle database instance.  The process monitor (PMON) performs process recovery when a user process fails. The DBWn processes are responsible for writing modified (dirty) buffers in the database buffer cache to disk  The log writer process (LGWR) is responsible for redo log buffer management—writing the redo log buffer to a redo log file on disk.Exploring Oracle Database Administration Oracle Architectural Components and Database Creation SUMMARY  An Oracle Data base is comprised of physical files. Tata Consultancy Services Limited (TCS).  The archiver process (ARCn) copies online redo log files to a designated storage device after a log switch has occurred. and automatic archiving is enabled.  The system monitor process (SMON) performs crash recovery.  A program global area (PGA) is a memory region.  The recoverer process (RECO) is a background process used with the distributed database configuration that automatically resolves failures involving distributed transactions.  The redo log buffer is a circular buffer in the SGA that holds information about changes made to the database. ARCn processes are present only when the database is in ARCHIVELOG mode.  The parameters which control the location and size of trace files are: © Copyright 2006.  The queue monitor process is an optional background process for Oracle Advanced Queuing.  The command for starting an instance without mounting the database is STARTUP NOMOUNT. memory and processes.  The total size of the shared pool is determined by the initialisation parameter SHARED_POOL_SIZE.  The database writer process (DBWn) writes the contents of buffers to data files.  A shared SQL area contains the parse tree and execution plan for a given SQL statement. This combination of the SGA and the Oracle processes is called an Oracle instance. which contains data and control information for a server process.  To shut down the database in normal conditions the command used is SHUTDOWN NORMAL.  The database buffer cache is the portion of the SGA that holds copies of data blocks read from data files.  Oracle allocates a memory area called the System Global Area (SGA) and starts one or more Oracle processes. which monitors the message queues. 40 . if necessary. at instance startup.  The command for starting an instance and mounting the database is STARTUP MOUNT.  To shutdown the database immediately use SHUTDOWN IMMEDIATE command.

This block size is used in creation of SYSTEM table space and by default in other table spaces. 41 .Exploring Oracle Database Administration ♦ ♦ ♦ Oracle Architectural Components and Database Creation BACKGROUND_DUMP_DEST USER_DUMP_DEST MAX_DUMP_FILE_SIZE  Password file can be created by a utility called ORAPWD. © Copyright 2006.  The PROCESSES initialisation parameter determines the maximum number of operating system processes that can be connected to Oracle concurrently.  The DB_BLOCK_SIZE initialisation parameter specifies the standard block size for the database.  Oracle Universal Installer is a Java-based graphical user interface (GUI) tool that enables you to install Oracle components from your CD-ROM. Tata Consultancy Services Limited (TCS).

2. 4. –DATA DICTIONARY---. 3. State whether the following are True/False 1. 3. 2. SMON performs process recovery (T/F).is a collection of database tables and views.and –ORACLE PROCESS-. –REDO LOG BUFFER -. 2.contains data and control information of an Oracle Instance. The recoverer process (RECO) is a background process used with the distributed database configuration that automatically resolves failures involving distributed transactions (T/F). 6. Log Writer Process writes contents of buffers to data files (T/F). 7. 5. --SGA------. 3.ora parameter JOB_QUEUE_PROCESSES represents the maximum number of job queue processes that can concurrently run on an instance (T/F). 5. 8. Tata Consultancy Services Limited (TCS). The size of the cache of the data blocks is determined by ---DB_BLOCK_SIZEparameter 4. What is SGA and what does it comprise of? What does background process RECO do? What is an Oracle Instance? What are various options of starting and shutting down a database ? What is the role of alert file? Write short notes on ORAPWD? When are Oracle Managed files used? What are the prerequisites for data base creation? © Copyright 2006. 6. Database writer process writes data in redo log buffer to redo log file (T/F). Answer the following Questions: 1.holds information about changes made to the database. --SGA-----. PMON process performs Crash Recovery (T/F). The init.constitute an Oracle Instance. 4. 5. 42 .Exploring Oracle Database Administration Oracle Architectural Components and Database Creation SELF-ASSESSMENT Fill in the blanks: 1.

rdo and log2a.con located in the directory "/home1/oracle9i/testdb/control/control01. The Character set WE8ISO8859P1 viii. Create additional table spaces called users and indx Create the data dictionary views. Maximum of 30 data files that can be created for the database vi.ctl" iii. The Trace file location should be in the BDUMP and CDUMP directory. 43 . 4. A maximum number of 100 archived redo logs for automatic media recovery vii. Two redo log file groups each one 150K member named log1a. Where is the existing control file and what is its name Try to start the database without the control file. One control file named control01. Database name and Instance name: TESTDB ii. A 20M data file named system01.dbf and located in /home1/oracle9i/testdb/system01. Write a script for creation of database with the following configuration: i. Tata Consultancy Services Limited (TCS). 2. What happens? © Copyright 2006.dbf' directory v. 3.log' The maximum number of five logs files groups and five log file Members for each group iv.rdo located in the directory '/home1/oracle9i/testdb/redo01.Exploring Oracle Database Administration Oracle Architectural Components and Database Creation LAB EXERCISES 1. 5.

Sign up to vote on this title
UsefulNot useful

Master Your Semester with Scribd & The New York Times

Special offer for students: Only $4.99/month.

Master Your Semester with a Special Offer from Scribd & The New York Times

Cancel anytime.