以下是對建立Oracle資料庫的三種方法進行了詳細的分析介紹,需要的朋友可以過來參考下
1.通過運行Oracle Database Configuration Assistant 建立、配置、或刪除資料庫(也可在命令列下輸入dbca);
2.用命令列的方式建立資料庫
3.通過運行自訂的批處理指令碼(或create_ORACLE_SID.bat(create_ORACLE_SID.sql))來建立、配置、或刪除資料庫。
詳述:
1.通過運行Oracle Database Configuration Assistant 建立、配置、或刪除資料庫;
建議不熟悉建立過程的DBA使用該方法,只需要根據選項“下一步”進行配置,最後產生資料庫的建立指令碼(建議保留),或者直接建立資料庫;
優點:GUI方法使用方便;
缺點:不過建立過程有些慢;
2.用命令列的方式建立資料庫
複製代碼 代碼如下:
CONNECT / AS SYSDBA
STARTUP PFILE= 'C:oracleadmininit_testorcl.ora' NOMOUNT;
CREATE DATABASE testOrcl DATAFILE '/u02/oracle/testOrcl/system01.dbf' SIZE 100M
LOGFILE GROUP1 ('/u01/oracle/testOrcl/redo1a.log',
'/u02/oracle/testOrcl/redo1b.log') SIZE 500K,
GROUP2 ('/u01/oracle/testOrcl/redo1a.log',
'/u02/oracle/testOrcl/redo1b.log') SIZE 500K
CHARACTER SET ZHS16CGB231280;
--將資料庫直接從未建置狀態轉換到開啟狀態
ALTER DATABASE OPEN;
--刪除資料庫(Dropping a Database)
SPOOL C:DROP_DATABASE.BAT
SELECT 'DEL '||NAME 刪除資料庫相關資料檔案 FROM V$DATAFILE;
SELECT 'DEL '||MEMBER 刪除資料重構記錄檔 FROM V$LOGFILE;
SPOOL OFF;
優點:可以熟悉建立指令,建立原理;
缺點:配置簡單,要求熟記命令列指令;
3.通過運行自訂的批處理或SQL指令碼(create_ORACLE_SID.bat或create_ORACLE_SID.sql)來建立
複製代碼 代碼如下:
--create_ORACLE_SID.bat
set ORACLE_SID= ORACLE_SID.
del C:ORACLE8IdatabasepwdORACLE_SID.ora
C:ORACLE8Ibinoradim -new -sid ORACLE_SID. -intpwd oracle -startmode manual
-pfile C:ORACLE8IadminORACLE_SIDpfileinit.ora
C:ORACLE8Ibinsvrmgrl @C:WINNTProfilesAdministratorLbORACLE_SIDrun.sql
C:ORACLE8Ibinsvrmgrl @C:WINNTProfilesAdministratorLbORACLE_SIDrun1.sql
C:ORACLE8Ibinoradim -edit -sid ORACLE_SID -startmode auto
--ORACLE_SIDrun.sql
spool C:ORACLE8IadminORACLE_SIDcreatecreatedb
set echo on
connect INTERNAL/oracle
startup nomount pfile=C:ORACLE8IadminORACLE_SIDpfileinit.ora
CREATE DATABASE ORACLE_SID
LOGFILE 'C:ORACLE8IoradataORACLE_SIDredo01.log' SIZE 1024K,
'C:ORACLE8IoradataORACLE_SIDredo02.log' SIZE 1024K
MAXLOGFILES 32
MAXLOGMEMBERS 2
MAXLOGHISTORY 1
DATAFILE 'C:ORACLE8IoradataORACLE_SIDsystem01.dbf' SIZE 50M REUSE
MAXDATAFILES 254
MAXINSTANCES 1
CHARACTER SET ZHT16BIG5
NATIONAL CHARACTER SET ZHT16BIG5;
spool off
--ORACLE_SIDrun1.sql
spool C:ORACLE8IadminORACLE_SIDcreatecreatedb1
set echo on
connect INTERNAL/oracle
ALTER DATABASE DATAFILE 'C:ORACLE8IoradataORACLE_SIDsystem01.dbf' AUTOEXTEND ON;
CREATE ROLLBACK SEGMENT SYSROL TABLESPACE "SYSTEM" STORAGE (INITIAL 100K NEXT 100K);
ALTER ROLLBACK SEGMENT "SYSROL" ONLINE;
Linux平台下Oracle的操作
下面對Oracle的操作都是在Linux平台下進行的!
1.su Oracle
2.sqlplus /logon
3.connect test/test assysdba(test/test是Oracle使用者和密碼)
4.startup
5.lsnrctl
首選啟動資料庫
su - Oracle
sqlplus /nolog
conn /as sysdba
startup
然後啟動監聽:
進入/opt/Oracle/product/9.2.0/bin/
lsnrctl start
運行shudown命令關閉資料庫
[Oracle@wing /Oracle]$ sqlplus" / as sysdba" //以sysdba使用者登陸資料庫
SQL> shutdown
啟動Oracle 9i 資料庫
[Oracle@wing bin]$ sqlplus " /as sysdba"
SQL> startup
啟動Oracle 9i監聽程式
Oracle的監聽程式主要是為用戶端的串連提供介面
[Oracle@wing bin]$ lsnrctl
LSNRCTL> start
關閉Oracle 9i監聽程式
[Oracle@wing bin]$ lsnrctl
LSNRCTL> stop
先看看Oracle_SID 環境變數設定是否正確。
9i:
$ sqlplus /nolog
SQL> connect / as sysdba
SQL> startup
$ lsnrctl start
8i:
$ svrmgrl
SVRMGR> connect internal
SVRMGR> startup
$ lsnrctl start
在哪裡報錯??
一般只要設定這2處就好了~
/etc/oratab
ora2:/Oracle/app/Oracle/product/8.1.7:Y
/etc/inittab
oralce:2:wait:/bin/su - Oracle -c '/Oracle/app/Oracle/product/8.1.7/bin/lsnrctl start'
Oracle:2:wait:/bin/su - Oracle -c '/Oracle/app/Oracle/product/8.1.7/bin/dbstart'
啟動步驟:
su - Oracle
[Oracle@websvr1 Oracle]$ sqlplus /nolog
SQL> connect / as sysdba
SQL> startup
SQL> quit
[Oracle@websvr1 Oracle]$ lsnrctl start
可用 [Oracle@websvr1 Oracle]$ lsnrctl status 查看監聽是否已經啟動
關閉步驟:
su - Oracle
[Oracle@websvr1 Oracle]$ lsnrctl stop
[Oracle@websvr1 Oracle]$ sqlplus /nolog
SQL> connect / as sysdba
SQL> shutdown immediate
SQL> quit