Oracle10g 手工建庫

kuqlan發表於2012-04-12

環境:RedHat Enterprice Linux 5.4 、Oracle 10g,必須提前安裝好Oracle資料庫軟體。

1. 設定環境變數ORACLE_SID

假設要求建立的資料庫的SID是test

export ORACLE_SID=test

export ORALE_BASE=/var/oracle

2.手工建立如下目錄:

mkdir -p $ORACLE_BASE/admin/test/cdump

mkdir -p $ORACLE_BASE/admin/test/bdump

mkdir -p $ORACLE_BASE/admin/test/udump

mkdir -p $ORACLE_BASE/admin/test/adump

mkdir -p $ORACLE_BASE/oradata/test

[@more@]

3. 建立最簡單的initTEST.ora檔案

cd $ORALE_HOME/dbs

cat init.ora | grep -v ^# | grep -v ^$ > initSID.ora

db_name=TEST

control_files=("/oracle/oradata/TEST/controlfile01.dbf")

sga_max_size=280M

sga_target=280M

note:刪除其他記憶體引數

[oracle@node2 dbs]$ more inittest.ora

db_name=test

control_files = ($ORACLE_BASE/oradata/test/ora_control1.ctl, $ORACLE_BASE/oradata/test/ora_control2.ctl, $ORACLE_BASE/oradata/test/ora_control3.ctl)

sga_max_size=280M

sga_target=280M

db_block_size=8192

background_dump_dest=$ORACLE_BASE/admin/test/bdump

core_dump_dest=$ORACLE_BASE/admin/test/cdump

user_dump_dest=$ORACLE_BASE/admin/test/udump

audit_file_dest=$ORACLE_BASE/admin/test/udump

undo_management=auto

undo_tablespace=undotbs1

job_queue_processes=5

---如下可選,

#job_queue_processes=5 #建立em時需要job_queue_processes>1

#db_create_file_dest = 考題中要求你建立資料檔案時存放的目錄

#db_create_online_log_dest_1 = 考題中要求你建立聯機重做日誌檔案時存放的目錄

4. 啟動資料庫到nomount狀態

此時已經有可供啟動的初始化引數檔案了,將資料庫啟動到nomount狀態。

SQL> startup nomount;

5. 建立spfile

例項啟動以後立刻建立spfile,然後重啟一次資料庫,讓資料庫能夠使用到spfile。

SQL> create spfile from pfile;

6.建立密碼檔案

用orapwd程式建立orapwTEST密碼檔案,如果記不清楚orapwd程式怎麼用,直接敲orapwd然後回車,會告訴你語法是怎樣的。

orapwd file=$ORACLE_HOME/dbs/orapwtest password=oracle entries=5

7. 要快速找到例句要查的是Administrator’s Guide這本文件中第二章 Creating an Oracle Database -> Creating the database -> Issue the CREATE DATABASE Statement,這裡有完整的一條SQL語句,copy出來,然後按照實際需求編輯相應的地方, 然後執行NOTE:修改MAXLOGFILES,undo,default)。

具體如下:

[oracle@node2 ~]$ vi createdb.sql

CREATE DATABASE TEST

USER SYS IDENTIFIED BY oracle

USER SYSTEM IDENTIFIED BY oracle

LOGFILE GROUP 1 ('/var/oracle/oradata/test/redo01.log') SIZE 10M,

GROUP 2 ('/var/oracle/oradata/test/redo02.log') SIZE 10M,

GROUP 3 ('/var/oracle/oradata/test/redo03.log') SIZE 10M

MAXLOGFILES 30

MAXLOGMEMBERS 5

MAXLOGHISTORY 1

MAXDATAFILES 200

MAXINSTANCES 2

CHARACTER SET ZHS16GBK

NATIONAL CHARACTER SET AL16UTF16

DATAFILE '/var/oracle/oradata/test/system01.dbf' SIZE 325M REUSE EXTENT MANAGEMENT LOCAL

SYSAUX DATAFILE '/var/oracle/oradata/test/sysaux01.dbf' SIZE 325M REUSE

DEFAULT TEMPORARY TABLESPACE tempts1 TEMPFILE '/var/oracle/oradata/test/temp01.dbf' SIZE 20M REUSE

UNDO TABLESPACE undotbs1 DATAFILE '/var/oracle/oradata/test/undotbs01.dbf'

SIZE 200M REUSE AUTOEXTEND ON MAXSIZE UNLIMITED;

SQL> startup nomount;

ORACLE instance started.

Total System Global Area 293601280 bytes

Fixed Size 2020320 bytes

Variable Size 92277792 bytes

Database Buffers 197132288 bytes

Redo Buffers 2170880 bytes

SQL> @createdb.sql

Database created.

SQL>

8.建立預設表空間

[oracle@node2 ~]$ sqlplus / as sysdba

SQL> CREATE SMALLFILE TABLESPACE "USERS" DATAFILE '/var/oracle/oradata/test/users01.dbf' SIZE 5M REUSE AUTOEXTEND ON NEXT 1280K MAXSIZE UNLIMITED EXTENT MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT AUTO;

SQL> ALTER DATABASE DEFAULT TABLESPACE "USERS";

9. 執行catalog.sql(建資料字典檢視) 和 catproc.sql(建儲存過程包)

只需要執行這兩個SQL,都在$ORACLE_HOME/rdbms/admin中,建立必須的資料字典和內建的package等

SQL>spool /home/oracle/cat.log

SQL>@?/rdbms/admin/catalog.sql

SQL>@?/rdbms/admin/catproc.sql

10.建立SQL PLUS屬性和幫助(可選)

connect system/oracle

@?/sqlplus/admin/pupbld.sql

@?/sqlplus/admin/help/hlpbld.sql helpus.sql

connect /as sysdba

@?/rdbms/admin/catblock.sql(建鎖相關的檢視)

@?/rdbms/admin/catoctk.sql (建密碼工具包dbms_crypto_toolkit

@?/rdbms/admin/owminst.plb(建工作空間管理相關物件,dbms_wm

最終可以檢視一些狀態

select open_mode, name from v$database;

select current_scn, CHECKPOINT_CHANGE# from v$database;

select startup_time,status from v$instance;

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/18841027/viewspace-1057891/,如需轉載,請註明出處,否則將追究法律責任。

相關文章