Oracle SQL*PLUS基礎及sqlplus命令詳解 (轉)

csbwolf10發表於2010-03-15

 

1.2 關聯式資料庫系統(RDBMS)的組成
RDBMS由兩部分組成,即資料庫系統核心(軟體)和資料字典(核心用於管理資料庫系統的資料結構)兩部分。

§1.2.1 RDBMS 核心
RDBMS就是用來控制資料訪問的作業系統。它的任務是按照一定的規則儲存資料、檢索資料及保護資料。

§1.2.2 資料字典概念
資料自動存放資料庫中所有物件(如表,索引,檢視等)所需的資訊。Oracle 8i 的資料字典是存放資料庫系統資訊的一組表,從資料字典中的資訊可以確認資料庫中資料物件的基本資訊及存放位置。

§1.3 SQL、SQL*Plus及 PL/SQL
下面用簡單的語言解釋Oracle的常用產品所包含的SQL*PLUS和PL/SQL的關係。
§1.3.1 SQL和SQL*PLUS的差別
SQL是標準結構查詢語言,而SQL*PLUS實際是包括標準的SQL和Oracle公司的一些命令組成的產品,因而Oracle公司將其取名為SQL*PLUS。下面是它們的解釋。

1. SQL(Structured Query Language)

SQL有許多關鍵字,以下語句是常用於開頭的語句:
Alter Insert
Audit Lock
Commit Noaudit
Comment Rename
Create Revoke
Delete Select
Drop Update
Grant Validate

注:
1.Oracle的SQL緩衝區一次只能存放一條SQL命令;
2.Validate (使生效) 在 oracle 中跟 Enable 一起用,但可以省去 Validate,所以許多資料都不介紹Validate 的用法。其語法如:
Enable{[Validate][Novalidate]} { [UNIQUE][PRIMARY KEY]... } ...

2. SQL*PLUS

除SQL外,SQL*PLUS還包括稱為SQL*PLUS命令的附加命令,這些命令主要用於形成複雜報表,編輯SQL命令,提供幫助資訊,維護系統等。SQL*PLUS包括的命令如下:

@ Connect
Host Set
# Copy
Input Show
$ Define
List Spool
/ Del
Newpage Sqlplus
Accept Describe
Pause Start
Append Disconnect
Quit Timing
Break Document
Remark Ttitle
Btitle Edit
Prompt Undefine
Chang Execute
Print Save
Clear Exit
Run Column
Get Runform
Compute Help

3. DDL(Data Define Language)

對於結構查詢語言(有時稱SQL命令),可以將它們分成兩組,一組是資料定義語言(DDL);另一組是資料操縱語言(DML)。其中用於資料定義的語言如下:

Alter procedure 重編譯過程
Alter table 修改表的屬性
Analyze 統計資料庫物件效能值
Alter table add Constraint 對已有的表加約束
Create table 建立表結構
Create index 建立索引
Drop table 刪除表實體及相關的索引
Drop index 刪除索引
Grant 授權給使用者或角色
Truncate 刪除表中的所有行
Revoke 從使用者或角色收回許可權

4.DML(Data Manipulation Language)

對於結構查詢語言的另一組是資料操縱語言(DML)。DML其中用於資料操縱的命令如下:

Insert
Delete
Update
Commit work
Rollback

§1.3.2 PL/SQL語言
PL/SQL是Oracle RDBMS (Oracle 6 之後版本)的一個組成部分,PL 是“過程化語言(Procedure Language )”的縮寫。PL/SQL語言是在SQL語言中結合了結構化過程語言成分的準第四代語言。

使用PL/SQL的目的:
由於大多數PL/SQL是在服務端來執行,這樣可減少由客戶端執行程式時所需的網路資料流量。
可以使用PL/SQL的地方:
l PL/SQL可以單獨進行程式的編寫,完成一般的處理功能;
l 在高階語言中可嵌入PL/SQL 塊;
l 在4GL中可以嵌入PL/SQL 塊;
l 在PL/SQL程式中可以嵌入 HTML和XML。

§1.4 登入到SQL*PLUS
我們建立任何物件,如建立表、索引等都需要連線到Oracle中,這裡用“登入”主要是Oracle的介面提供的是Login 這樣的叫法。其實就是連線的意思。在Client/Server結構下,Oracle提供兩種方式連線SQL*PLUS,其中SQL*NET V2.x 版本(目前版本不再使用SQL*NET V2.x)提供在字元方式下連線到 SQL*PLUS,SQL*NET V2. x版本提供在圖形方式(Window)使用,目前版本的 ORACLE8/8i 都使用 NET8 連線.(NET8 不再支援字元終端)

§1.4.1 UNIX環境
在UNIX下,要確保客戶端或伺服器端與Oracle伺服器系統進行連線,必須保證tnsnames.ora和listener.ora兩個引數檔案的正確配置。詳細的配置解釋在DBA章節裡解釋。下面是tnsnames.ora和listener.ora兩個引數檔案的內容顯示。

1. tnsnames.ora引數檔案:
INST1_HTTP =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = dbsvr)(PORT = 1521))
)
(CONNECT_DATA =
(SERVER = SHARED)
(SERVICE_NAME = s450)
(PRESENTATION = http://admin)
)
)

EXTPROC_CONNECTION_DATA =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC))
)
(CONNECT_DATA =
(SID = PLSExtProc)
(PRESENTATION = RO)
)
)

S450 =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = dbsvr)(PORT = 1521))
)
(CONNECT_DATA =
(SERVICE_NAME = s450)
)
)

2. listener.ora引數檔案:
LISTENER =
(DESCRIPTION_LIST =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = dbsvr)(PORT = 1521))
)
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC))
)
)
)

SID_LIST_LISTENER =
(SID_LIST =
(SID_DESC =
(SID_NAME = PLSExtProc)
(ORACLE_HOME = /home/oracle/app/oracle/product/8.1.7)
(PROGRAM = extproc)
)
(SID_DESC =
(GLOBAL_DBNAME = s450)
(ORACLE_HOME = /home/oracle/app/oracle/product/8.1.7)
(SID_NAME = s450)
)
)

如果安裝後已經正確地對上面的兩個引數檔案進行配置,則可以按照下面步驟進行登入:

1)先啟動伺服器端監聽器:
lsnrctl start

2)用下面命令顯式登入到 SQL*PLUS:
$sqlplus username/password

$SQLPLUS username/password@connect_string

3)用下面命令隱式登入到 SQL*PLUS:
$sqlplus [enter]
Enter user name:scott
Enter password:******

§1.4.2 Windows NT和WINDOWS/2000環境
在NT/2000環境下,要使客戶端能與Oracle伺服器進行連線,tnsnames.ora和listener.ora引數檔案的配置如下:

1. tnsnames.ora引數檔案:

ORA816.TAIJI.COM.CN =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = zhao)(PORT = 1521))
)
(CONNECT_DATA =
(SERVICE_NAME = ora816)
)
)

EXTPROC_CONNECTION_DATA.TAIJI.COM.CN =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1))
)
(CONNECT_DATA =
(SID = PLSExtProc)
(PRESENTATION = RO)
)
)
S450 =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = dbsvr)(PORT = 1521))
)
(CONNECT_DATA =
(SERVICE_NAME = s450)
)
)

2. listener.ora引數檔案:

LISTENER =
(DESCRIPTION_LIST =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1))
)
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = zhao)(PORT = 1521))
)
)
(DESCRIPTION =
(PROTOCOL_STACK =
(PRESENTATION = GIOP)
(SESSION = RAW)
)
(ADDRESS = (PROTOCOL = TCP)(HOST = zhao)(PORT = 2481))
)
)

SID_LIST_LISTENER =
(SID_LIST =
(SID_DESC =
(SID_NAME = PLSExtProc)
(ORACLE_HOME = D:\oracle)
(PROGRAM = extproc)
)
(SID_DESC =
(GLOBAL_DBNAME = ora816)
(ORACLE_HOME = D:\oracle)
(SID_NAME = ora816)
)
)

Windows NT/2000字元方式登入步驟:
1)先啟動伺服器端監聽器:
lsnrctl start

2)用下面命令顯式登入到 SQL*PLUS:
$sqlplus username/password

$SQLPLUS username/password@connect_string

Windows NT/2000圖形方式登入步驟:
1)點選“開始”=》“程式”=》“Oracle –OraHome81”=》“Application on Development”=》“SQL Plus”進入如下螢幕:

在WINDOWS NT/98/2000上的登入介面(sqlplus圖)

可以在使用者名稱框內輸入使用者、口令及主機字串;也可以分別進行輸入。

§1.5 常用SQL*PLUS 附加命令簡介
Oracle公司提供的附加語句(或稱命令),可以滿足程式人員和管理員的一些特殊操作要求。比如,在顯示超過上百行記錄資訊時,可以採用每屏“暫停”來實現。要達到這樣的目的,就要在SQL>下發 set pause on 命令。由於SQL*PLUS命令較多,下面僅給出最常用的幾個命令的說明,詳細的請參考附錄。
§1.5.1 登入到SQL*PLUS

可以用下面命令登入到 SQL*PLUS,SQL*PLUS命令的簡單語法如下:

SQLPLUS [ [logon] | [start] ]

logon可以是:
{username[/password][@connect_identifier]|/} [AS {SYSOPER|SYSDBA}]
|/NOLOG

注1:SQLPLUS 主要是在命令方式下使用,在NT、WINDOWS/2000、UNIX的用法都一樣。
注2:如果在UNIX下,SQLPLUS命令不被識別(不存在),則問題在環境變數PATH沒有設定正確或者沒有設定。SQLPLUS 可執行程式在$ORACLE_HOME/bin 目錄下。

§1.5.2 EXIT和QUIT

可以用 exit 或quit 來終止SQL*PLUS的操作(會話)。語法如下:

{EXIT|QUIT} [SUCCESS|FAILURE|WARNING ]

{EXIT|QUIT} 可以用exit 或quit ,目前它們的功能一樣。

SUCCESS 正常退出

FAILURE 帶提示錯誤程式碼的退出

WARNING 帶提示警告程式碼的退出

COMMIT 退出前將未提交進行儲存

例如:
SQL>exit

§1.5.3 DESCRIBE(顯示錶、檢視結構)
DESCRIBE可以用(只要用DESC即可)來顯示錶、檢視的列的定義,也可以顯示同義詞、函式或儲存過程的說明。語法如下:

DESC[RIBE] {[schema.]object[@connect_identifier]}

Schema:使用者名稱,如果省去,則為物件的所有者。

object
可以是 表(table), 檢視(view),型別( type), 儲存過程(procedure),函式( function), 包(package)或同義詞( synonym)

@connect_identifier
資料庫連線字串

例:顯示emp 表的結構:

SQL>desc emp

§1.5.4 LIST(列出)命令
可以用 LIST 命令來列出當前SQL緩衝區中的一行或多行命令語句。

L[IST] [n|n m|n *|n LAST|*|* n|* LAST|LAST]

n 列出第n行
n m 列出n到m行
n * 列出第n行到當前行
n LAST 列出第n行到最末行
* 列出所有行
* n 列出當前行到第n行
* LAST列出當前行到最末行
LAST 列出最末行

例:
SQL> LIST
1 SELECT ENAME, DEPTNO, JOB
2 FROM EMP
3 WHERE JOB = ’CLERK’
4* ORDER BY DEPTNO

§1.5.5 Change(替換字串)命令

可以用Change命令來改變字串(即替換字串)。語法如下:

C[HANGE] sepchar old [sepchar [new [sepchar]]]

Sepchar 為分隔符,可以是”/” 或”!” -- 請使用者特別注意

Old 舊字串

New 新字串

例:將 除號(/)改為 乘號( * ),則需要命令為c !/!*! 。即:
SQL> l
1* select sal,sal/100 from emp
SQL> c !/!*!

提醒:對於修改 / 字元的只能用 ! 來作分隔符(上例)。

例:將乘號( * )改為 加號( + ),則需要命令為c !/!*! 。即:
SQL> l
1* select sal,sal*100 from emp
SQL> c/*/+/
1* select sal,sal+100 from emp
SQL>

§1.5.6 Append(追加字串)命令

可以用 Append命令來完成在當前行的末尾追加字串。語法如下:

A[PPEND] text

Text 所要求追加的字串

例:在當前行select sal,sal+100 from emp 後加 where sal>=2000,則:

SQL> l
1* select sal,sal+100 from emp
SQL> a where sal>=2000
1* select sal,sal+100 from emp where sal>=2000
SQL>

§1.5.7 Save儲存當前緩衝區命令到檔案

可以用SAVE命令將當前的命令列儲存到作業系統的檔案中。語法如下:

SAV[E] filename[.ext] [CRE[ATE]|REP[LACE]|APP[END]]

其中:
filename:你將把緩衝區中的內容存入到作業系統目錄的檔名。
ext:若使用檔案字尾,預設的檔案字尾為SQL。

例:
SQL>select table_name from dict where table_name like ‘%ROLE%’;
SQL>save c:\get_role

§1.5.8 GET將命令檔案讀到緩衝區
可以用GET 命令將作業系統的目錄下的命令檔案讀到緩衝區(但不執行)。語法如下:

GET filename [.ext] [LIS[T]|NOL[IST]]
其中:
filename: 希望載入到SQL緩衝區的檔名
ext: 檔案的副檔名,預設為 SQL.

例:

SQL>get c:\get_role

§1.5.9 SPOOL將資訊記錄到檔案中
Oracle的SPOOL 命令可以實現將螢幕所出現的一切資訊記錄到作業系統的檔案中直到SPOOL OFF為止。語法如下:

SPO[OL] [filename[.ext] | OFF | OUT]
其中:
filename:你想輸出(spool)的檔名。
ext:檔案的字尾。預設的字尾是LST(或LIS)。

SQL>col table_name for a20
SQL>col comments for a80
SQL>set linesize 110
SQL>SPOOl c:\all_dict
SQL>select table_name,comments from dict;
. . . . . . (系統查詢資訊)

SQL>SPOOL OFF

§1.5.10 再執行當前緩衝區的命令
在SQL>方式下,如果希望在執行當前的命令,可用Run(或R)或用 / 來實現,如:

SQL> set lin 120
SQL> select table_name from dict where table_name like '%ROLE%';

TABLE_NAME
------------------------------
DBA_ROLES
DBA_ROLE_PRIVS
USER_ROLE_PRIVS
ROLE_ROLE_PRIVS
ROLE_SYS_PRIVS
ROLE_TAB_PRIVS
SESSION_ROLES

已選擇7行。

SQL> l
1* select table_name from dict where table_name like '%ROLE%'
SQL> /

TABLE_NAME
------------------------------
DBA_ROLES
DBA_ROLE_PRIVS
USER_ROLE_PRIVS
ROLE_ROLE_PRIVS
ROLE_SYS_PRIVS
ROLE_TAB_PRIVS
SESSION_ROLES

已選擇7行。

§1.6 常用資料字典簡介
ORACLE 提供許多內部資料字典, 用以管理系統的各種資訊和引數(即資料庫物件),下面列出幾個常用的資料字典供初學者參考,其它方面的資料字典將在DBA管理中介紹。

ORACLE 資料字典的命名說明:

USER 為字首----記錄使用者的所有物件資訊
ALL 為字首----記錄包括 USER 記錄和授權給PUBLIC 或該用
戶的所有物件的資訊。
DBA 為字首----記錄關於資料庫物件(非使用者物件)的資訊。
V$ 公共系統動態檢視,用於系統優化和調整參考.
V_$ 動態效能檢視,你可用 CATALOG.SQL 指令碼建立動態檢視建立同義詞。
GV$ 新(oracle 8)的附加的固定檢視(Global V$).在並行環境下反應的是
V$檢視的資訊。如:

SELECT * FROM GV$LOCK WHERE INST_ID = 2 OR INST_ID = 5 ;

返回的是instances 2 和5的V$的資訊。所以GV$反應一組Instances的引數. GV$檢視的限制是引數PARALLEL_MAX_SERVERS必須大於0 。
詳見 Oracle Enterprise Manager Administrator's Guide.

注:請注意下面的總結:
l 一般DBA_ 的檢視內容都包含USER_和ALL_為字首的檢視;
l DBA_為字首的檢視的內容基本上是大寫;
l 以V$_為字首的檢視的內容基本上是小寫。

1. USER_TABLEs(=TABS) 使用者的所有表的資訊。
2.USER_TAB_COLUMNS(=COLS) 有關各表的列(欄位)的資訊
3.USER_VIEWS 使用者的所有檢視
4.USER_SYNONYMS(=SYN) 使用者同義詞
5.USER_SEQUENCES(=SEQ) 使用者序列
6.USER_CONSTRAINTS 記錄建立表結構時建立的限制。
7.USER_TAB_COMMENTS 表的註釋。如:

Comment on table emp is '職工表';

8. USER_COL_COMMENTS 列(欄位)註釋。如:

Comment on column emp.ename is '姓名';

9. USER_INDEXES(=IND) 使用者索引的簡要資訊
10. USER_IND_COLUMNS 使用者索引的列資訊
11. USER_TRIGGERS 使用者觸發器資訊
12. USER_SOURCE 使用者儲存過程
13. USER_TABLESPACE 使用者可以使用的表空間資訊
14. USER_TS_QUOTAS 使用者使用系統資源的資訊
15. USER_SEGMENTS 使用者物件所使用空間資訊
16. USER_EXTENTS 使用者的擴充套件段資訊
17. USER_OBJECTS 使用者物件
=USER_TABLES+USER_VIEWS+USER_INDEXES+
USER_SOURCE+USER_TRIGGERS+USER_JAVA

18. USER_PART_TABLES 使用者分割槽資訊
19. USER_TAB_PARTITIONS
20. USER_PART_COL_STATISTICS
21. USER_IND_PARTITIONS
22. USER_FREE_SPACE
23. CAT(=USER_CATALOG) 使用者可以訪問的所有的基表。
24. TAB 使用者建立的所有基表,檢視,同義詞等。
25. DICT(=DICTIONARY) 構成資料字典的所有表的資訊。

提示:雖然Oracle提供可以用Comment on column tablename.column is 'xxxx'; 等來實現對錶或列進行註釋,但不建議設計者採用這樣的工作方式。而建議將註釋寫到指令碼中更為直觀。

§1.7 ORACLE資料型別
Oracle資料庫的資料型別與其它的資料庫系統相比,它的資料型別不多,Oracle在表示資料方面比其他資料庫系統來說要省去許多關鍵字。 Oracle只用NUMBER(m,n)就可以表示任何複雜的數字資料。其它如日期型別等也簡單得多,只DATE就表示日期和時間。下面以列表形式給出各個版本的Oracle系統資料型別的表示方法。下面給出Oracle舊版本的資料型別的目的是讓讀者瞭解Oracle的變化,另外就是你在對舊版本進行升級或資料轉換時要注意各個版本的差別。

ORACLE5、ORACLE6資料型別

資料型別 說明
Char 可變長字元型,≤254
Varchar2 可變長字元型,≤2000
Number(m,n) 數字型別,含整數、小數等
Date 日期型,含時間,預設格式為mmm-dd-yyyy hh:mi:ss(佔7位元組)
Long 儲存大型可變長字串,≤2GB
Raw 儲存短二進位制串,≤2GB
Long raw 儲存長二進位制串,≤2GB

§1.10 使用SQL Worksheet工作
在新的Oracle版本里,系統提供了一個叫SQL Worksheet 的圖形SQL工作環境,它是ORACLE Enterprise Manager 的一部分。使用它可以免去在SQL>下編輯行命令的不便。它完全是在圖形方式進行。它的啟動有以下幾種方法:
l 從ORACLE Enterprise Manager中啟動
l 從Administrtor 工具中啟動
l 從作業系統中啟動

下面給出在作業系統下啟動SQL Worksheet 工具工作的步驟:
1) 點選 SQL Worksheet 圖示,即選擇 開始->程式->Oracle-OraHome81->database Administration->SQLPLUS Worksheet。選中SQLPLUS Worksheet後出現如下畫面:

圖 1.10-1 使用SQL Worksheet 的登入畫面

在使用者名稱、口令及服務輸入ORACLE的有效使用者名稱、口令及連線字串再點選確定後進入如圖1.10-2所示的畫面。

2)當進入圖1.10-2 所示的畫面後。你就可以工作了。目前的版本是在螢幕的上方輸入命令,螢幕的下方是系統顯示結果。

3)我們將游標點選到螢幕上方,輸入SQL命令,如輸入:
select ename, sal from scott.emp;
輸入完成命令後,用游標點選 左邊的執行圖示,Oracle 會結果顯示在螢幕的下方:

圖 1。10-2 登入成功後的畫面

圖1.10-3 查詢命令及顯示結果畫面

從SQL Worksheet 工具中可以看出,該工具提供了相當豐富的功能。下面給出個功能的簡要說明:

1.檔案:
l 改變資料庫連線:可以連線到另外的使用者和資料庫上去;
l 開啟:可以開啟現有檔案;
l 將輸入另存為:將當前命令存為一個檔案;
l 將下方顯示的結果存為一個檔案。
2.編輯:
l 剪下:將當前選中字元進行剪下;
l 複製:將選中字元進行剪下;
l 貼上:將緩衝區字元進行貼上;
l 全選:對當前畫面所有字元全選;
l 全部清除:清除目前的所有內容。

3.工作單:
l 執行:執行當前的命令;
l 執行本地指令碼:執行作業系統下某個.SQL檔案(點選後提示輸入檔名);
l 命令歷史記錄:檢視命令歷史記錄;
l 上一條命令:顯示上一條命令。

提示:如果你的SQL Worksheet顯示的不是漢字(出現亂字元),請你將你的NT/2000/98環境下的漢字變數設定與伺服器的一樣就好了。在WINDOWS NT環境設定漢字變數步驟:

用regedit 修改登錄檔中的所有ORACLE字符集項,如:
1)點選:開始=》執行=》輸入regedit;
2)點選“HEY_LOCAL_MACHINE”左邊的“+”以展開目錄;
3)點選“SOFTWARE”左邊的“+”以展開目錄;
4)點選“ORACLE”項;
5)修改ORACLE樹下所有“NLS”變數與props$中的一致。

關於漢字環境變數的設定,請參閱《Oracle8i/9I初級資料庫管理》。

-----------------------------------------------

一、Oracle的啟動和關閉
1、在單機環境下要想啟動或關閉ORACLE系統必須首先切換到ORACLE使用者,如下
su - oracle

a、啟動ORACLE系統
oracle>svrmgrl
SVRMGR>connect internal
SVRMGR>startup
SVRMGR>quit

b、關閉ORACLE系統
oracle>svrmgrl
SVRMGR>connect internal
SVRMGR>shutdown
SVRMGR>quit

啟動oracle9i資料庫命令:
$ sqlplus /nolog

SQL*Plus: Release 9.2.0.1.0 - ProdUCtion on Fri Oct 31 13:53:53 2003

Copyright (c) 1982, 2002, Oracle Corporation. All rights reserved.

SQL> connect / as sysdba
Connected to an idle instance.
SQL> startup^C

SQL> startup
ORACLE instance started.

2、在雙機環境下要想啟動或關閉ORACLE系統必須首先切換到root使用者,如下
su - root

a、啟動ORACLE系統
hareg -y oracle

b、關閉ORACLE系統
hareg -n oracle

Oracle資料庫有哪幾種啟動方式

說明:

有以下幾種啟動方式:
1、startup nomount
非安裝啟動,這種方式啟動下可執行:重建控制檔案、重建資料庫

讀取init.ora檔案,啟動instance,即啟動SGA和後臺程式,這種啟動只需要init.ora檔案。

2、startup mount dbname
安裝啟動,這種方式啟動下可執行:
資料庫日誌歸檔、
資料庫介質恢復、
使資料檔案聯機或離線,
重新定位資料檔案、重做日誌檔案。

執行“nomount”,然後開啟控制檔案,確認資料檔案和聯機日誌檔案的位置,
但此時不對資料檔案和日誌檔案進行校驗檢查。

3、startup open dbname
先執行“nomount”,然後執行“mount”,再開啟包括Redo log檔案在內的所有資料庫檔案,
這種方式下可訪問資料庫中的資料。

4、startup,等於以下三個命令
startup nomount
alter database mount
alter database open

5、startup restrict
約束方式啟動
這種方式能夠啟動資料庫,但只允許具有一定特權的使用者訪問
非特權使用者訪問時,會出現以下提示:
ERROR:
ORA-01035: ORACLE 只允許具有 RESTRICTED SESSION 許可權的使用者使用

6、startup force
強制啟動方式
當不能關閉資料庫時,可以用startup force來完成資料庫的關閉
先關閉資料庫,再執行正常啟動資料庫命令

7、startup pfile=引數檔名
帶初始化引數檔案的啟動方式
先讀取引數檔案,再按引數檔案中的設定啟動資料庫
例:startup pfile=E:Oracleadminoradbpfileinit.ora

8、startup EXCLUSIVE
二、使用者如何有效地利用資料字典
 ORACLE的資料字典是資料庫的重要組成部分之一,它隨著資料庫的產生而產生, 隨著資料庫的變化而變化,
體現為sys使用者下的一些表和檢視。資料字典名稱是大寫的英文字元。

資料字典裡存有使用者資訊、使用者的許可權資訊、所有資料物件資訊、表的約束條件、統計分析資料庫的檢視等。
我們不能手工修改資料字典裡的資訊。

  很多時候,一般的ORACLE使用者不知道如何有效地利用它。

 dictionary   全部資料字典表的名稱和解釋,它有一個同義詞dict
dict_column   全部資料字典表裡欄位名稱和解釋

如果我們想查詢跟索引有關的資料字典時,可以用下面這條SQL語句:

SQL>select * from dictionary where instr(comments,'index')>0;

如果我們想知道user_indexes表各欄位名稱的詳細含義,可以用下面這條SQL語句:

SQL>select column_name,comments from dict_columns where table_name='USER_INDEXES';

依此類推,就可以輕鬆知道資料字典的詳細名稱和解釋,不用檢視ORACLE的其它文件資料了。

下面按類別列出一些ORACLE使用者常用資料字典的查詢使用方法。

1、使用者

檢視當前使用者的預設表空間

SQL>select username,default_tablespace from user_users;

檢視當前使用者的角色
SQL>select * from user_role_privs;

檢視當前使用者的系統許可權和表級許可權
SQL>select * from user_sys_privs;
SQL>select * from user_tab_privs;

2、表

檢視使用者下所有的表
SQL>select * from user_tables;

檢視名稱包含log字元的表
SQL>select object_name,object_id from user_objects
where instr(object_name,'LOG')>0;

檢視某表的建立時間
SQL>select object_name,created from user_objects where object_name=upper('&table_name');

檢視某表的大小
SQL>select sum(bytes)/(1024*1024) as "size(M)" from user_segments
where segment_name=upper('&table_name');

檢視放在ORACLE的記憶體區裡的表
SQL>select table_name,cache from user_tables where instr(cache,'Y')>0;

3、索引

檢視索引個數和類別
SQL>select index_name,index_type,table_name from user_indexes order by table_name;

檢視索引被索引的欄位
SQL>select * from user_ind_columns where index_name=upper('&index_name');

檢視索引的大小
SQL>select sum(bytes)/(1024*1024) as "size(M)" from user_segments
where segment_name=upper('&index_name');

4、序列號

檢視序列號,last_number是當前值
SQL>select * from user_sequences;

5、檢視

檢視檢視的名稱
SQL>select view_name from user_views;

檢視建立檢視的select語句
SQL>set view_name,text_length from user_views;
SQL>set long 2000; 說明:可以根據檢視的text_length值設定set long 的大小
SQL>select text from user_views where view_name=upper('&view_name');

6、同義詞

檢視同義詞的名稱
SQL>select * from user_synonyms;

7、約束條件

檢視某表的約束條件
SQL>select constraint_name, constraint_type,search_condition, r_constraint_name
from user_constraints where table_name = upper('&table_name');

SQL>select c.constraint_name,c.constraint_type,cc.column_name
from user_constraints c,user_cons_columns cc
where c.owner = upper('&table_owner') and c.table_name = upper('&table_name')
and c.owner = cc.owner and c.constraint_name = cc.constraint_name
order by cc.position;

8、儲存函式和過程

檢視函式和過程的狀態
SQL>select object_name,status from user_objects where object_type='FUNCTION';
SQL>select object_name,status from user_objects where object_type='PROCEDURE';

檢視函式和過程的原始碼
SQL>select text from all_source where wner=user and name=upper('&plsql_name');

三、檢視資料庫的SQL
1、檢視錶空間的名稱及大小

select t.tablespace_name, round(sum(bytes/(1024*1024)),0) ts_size
from dba_tablespaces t, dba_data_files d
where t.tablespace_name = d.tablespace_name
group by t.tablespace_name;

2、檢視錶空間物理檔案的名稱及大小

select tablespace_name, file_id, file_name,
round(bytes/(1024*1024),0) total_space
from dba_data_files
order by tablespace_name;

3、檢視回滾段名稱及大小

select segment_name, tablespace_name, r.status,
(initial_extent/1024) InitialExtent,(next_extent/1024) NextExtent,
max_extents, v.curext CurExtent
From dba_rollback_segs r, v$rollstat v
Where r.segment_id = v.usn(+)
order by segment_name ;

4、檢視控制檔案

select name from v$controlfile;

5、檢視日誌檔案

select member from v$logfile;

6、檢視錶空間的使用情況

select sum(bytes)/(1024*1024) as free_space,tablespace_name
from dba_free_space
group by tablespace_name;

SELECT A.TABLESPACE_NAME,A.BYTES TOTAL,B.BYTES USED, C.BYTES FREE,

(B.BYTES*100)/A.BYTES "% USED",(C.BYTES*100)/A.BYTES "% FREE"
FROM SYS.SM$TS_AVAIL A,SYS.SM$TS_USED B,SYS.SM$TS_FREE C
WHERE A.TABLESPACE_NAME=B.TABLESPACE_NAME AND A.TABLESPACE_NAME=C.TABLESPACE_NAME;

7、檢視資料庫庫物件

select owner, object_type, status, count(*) count# from all_objects group by owner, object_type, status;

8、檢視資料庫的版本

Select version FROM Product_component_version
Where SUBSTR(PRODUCT,1,6)='Oracle';

9、檢視資料庫的建立日期和歸檔方式

Select Created, Log_Mode, Log_Mode From V$Database;四、ORACLE使用者連線的管理

用系統管理員,檢視當前資料庫有幾個使用者連線:

SQL> select username,sid,serial# from v$session;

如果要停某個連線用

SQL> alter system kill session 'sid,serial#';

如果這命令不行,找它UNIX的程式數

SQL> select pro.spid from v$session ses,v$process pro where ses.sid=21 and ses.paddr=pro.addr;

說明:21是某個連線的sid數

然後用 kill 命令殺此程式號。

五、SQL*PLUS使用
a、近入SQL*Plus
$sqlplus 使用者名稱/密碼

退出SQL*Plus
SQL>exit

b、在sqlplus下得到幫助資訊
列出全部SQL命令和SQL*Plus命令
SQL>help
列出某個特定的命令的資訊
SQL>help 命令名

c、顯示錶結構命令DESCRIBE
SQL>DESC 表名

d、SQL*Plus中的編輯命令
顯示SQL緩衝區命令
SQL>L

修改SQL命令
首先要將待改正行變為當前行
SQL>n
用CHANGE命令修改內容
SQL>c/舊/新
重新確認是否已正確
SQL>L

使用INPUT命令可以在SQL緩衝區中增加一行或多行
SQL>i
SQL>輸入內容

e、呼叫外部系統編輯器
SQL>edit 檔名
可以使用DEFINE命令設定系統變數EDITOR來改變文字編輯器的型別,在login.sql檔案中定義如下一行
DEFINE_EDITOR=vi

f、執行命令檔案
SQL>START test
SQL>@test

常用SQL*Plus語句
a、表的建立、修改、刪除
建立表的命令格式如下:
create table 表名 (列說明列表);

為基表增加新列命令如下:
ALTER TABLE 表名 ADD (列說明列表)
例:為test表增加一列Age,用來存放年齡
sql>alter table test
add (Age number(3));

修改基表列定義命令如下:
ALTER TABLE 表名
MODIFY (列名 資料型別)
例:將test表中的Count列寬度加長為10個字元
sql>alter atble test
modify (County char(10));

b、將一張表刪除語句的格式如下:
DORP TABLE 表名;
例:表刪除將同時刪除表的資料和表的定義
sql>drop table test

c、表空間的建立、刪除
六、ORACLE邏輯備份的SH檔案

完全備份的SH檔案:eXP_comp.sh

rq=` date +"%m%d" `

su - oracle -c "exp system/manager full=y inctype=complete file=/oracle/export/db_comp$rq.dmp"

累計備份的SH檔案:exp_cumu.sh

rq=` date +"%m%d" `

su - oracle -c "exp system/manager full=y inctype=cumulative file=/oracle/export/db_cumu$rq.dmp"

增量備份的SH檔案: exp_incr.sh

rq=` date +"%m%d" `

su - oracle -c "exp system/manager full=y inctype=incremental file=/oracle/export/db_incr$rq.dmp"

root使用者crontab檔案
/var/spool/cron/crontabs/root增加以下內容

0 2 1 * * /oracle/exp_comp.sh

30 2 * * 0-5 /oracle/exp_incr.sh

45 2 * * 6 /oracle/exp_cumu.sh

當然這個時間表可以根據不同的需求來改變的,這只是一個例子。

七、ORACLE 常用的SQL語法和資料物件

一.資料控制語句 (DML) 部分

1.INSERT (往資料表裡插入記錄的語句)

INSERT INTO 表名(欄位名1, 欄位名2, ……) VALUES ( 值1, 值2, ……);
INSERT INTO 表名(欄位名1, 欄位名2, ……) SELECT (欄位名1, 欄位名2, ……) FROM 另外的表名;

字串型別的欄位值必須用單引號括起來, 例如: ’GOOD DAY’
如果欄位值裡包含單引號’ 需要進行字串轉換, 我們把它替換成兩個單引號''.
字串型別的欄位值超過定義的長度會出錯, 最好在插入前進行長度校驗.

日期欄位的欄位值可以用當前資料庫的系統時間SYSDATE, 精確到秒
或者用字串轉換成日期型函式TO_DATE(‘2001-08-01’,’YYYY-MM-DD’)
TO_DATE()還有很多種日期格式, 可以參看ORACLE DOC.
年-月-日 小時:分鐘:秒 的格式YYYY-MM-DD HH24:MI:SS

INSERT時最大可操作的字串長度小於等於4000個單位元組, 如果要插入更長的字串, 請考慮欄位用CLOB型別,
方法借用ORACLE裡自帶的DBMS_LOB程式包.

INSERT時如果要用到從1開始自動增長的序列號, 應該先建立一個序列號
CREATE SEQUENCE 序列號的名稱 (最好是表名+序列號標記) INCREMENT BY 1 START WITH 1
MAXVALUE 99999 CYCLE NOCACHE;
其中最大的值按欄位的長度來定, 如果定義的自動增長的序列號 NUMBER(6) , 最大值為999999
INSERT 語句插入這個欄位值為: 序列號的名稱.NEXTVAL

2.DELETE (刪除資料表裡記錄的語句)

DELETE FROM表名 WHERE 條件;

注意:刪除記錄並不能釋放ORACLE裡被佔用的資料塊表空間. 它只把那些被刪除的資料塊標成unused.

如果確實要刪除一個大表裡的全部記錄, 可以用 TRUNCATE 命令, 它可以釋放佔用的資料塊表空間
TRUNCATE TABLE 表名;
此操作不可回退.

3.UPDATE (修改資料表裡記錄的語句)

UPDATE表名 SET 欄位名1=值1, 欄位名2=值2, …… WHERE 條件;

如果修改的值N沒有賦值或定義時, 將把原來的記錄內容清為NULL, 最好在修改前進行非空校驗;
值N超過定義的長度會出錯, 最好在插入前進行長度校驗..

注意事項:
A. 以上SQL語句對錶都加上了行級鎖,
確認完成後, 必須加上事物處理結束的命令 COMMIT 才能正式生效,
否則改變不一定寫入資料庫裡.
如果想撤回這些操作, 可以用命令 ROLLBACK 復原.

B. 在執行INSERT, DELETE 和 UPDATE 語句前最好估算一下可能操作的記錄範圍,
應該把它限定在較小 (一萬條記錄) 範圍內,. 否則ORACLE處理這個事物用到很大的回退段.
程式響應慢甚至失去響應. 如果記錄數上十萬以上這些操作, 可以把這些SQL語句分段分次完成,
其間加上COMMIT 確認事物處理. 二.資料定義 (DDL) 部分

1.CREATE (建立表, 索引, 檢視, 同義詞, 過程, 函式, 資料庫連結等)

ORACLE常用的欄位型別有
CHAR 固定長度的字串
VARCHAR2 可變長度的字串
NUMBER(M,N) 數字型M是位數總長度, N是小數的長度
DATE 日期型別

建立表時要把較小的不為空的欄位放在前面, 可能為空的欄位放在後面

建立表時可以用中文的欄位名, 但最好還是用英文的欄位名

建立表時可以給欄位加上預設值, 例如 DEFAULT SYSDATE
這樣每次插入和修改時, 不用程式操作這個欄位都能得到動作的時間

建立表時可以給欄位加上約束條件
例如 不允許重複 UNIQUE, 關鍵字 PRIMARY KEY

2.ALTER (改變表, 索引, 檢視等)

改變表的名稱
ALTER TABLE 表名1 TO 表名2;

在表的後面增加一個欄位
ALTER TABLE表名 ADD 欄位名 欄位名描述;

修改表裡欄位的定義描述
ALTER TABLE表名 MODIFY欄位名 欄位名描述;

給表裡的欄位加上約束條件
ALTER TABLE 表名 ADD CONSTRAINT 約束名 PRIMARY KEY (欄位名);

ALTER TABLE 表名 ADD CONSTRAINT 約束名 UNIQUE (欄位名);

把表放在或取出資料庫的記憶體區
ALTER TABLE 表名 CACHE;
ALTER TABLE 表名 NOCACHE;

3.DROP (刪除表, 索引, 檢視, 同義詞, 過程, 函式, 資料庫連結等)

刪除表和它所有的約束條件
DROP TABLE 表名 CASCADE CONSTRAINTS;

4.TRUNCATE (清空表裡的所有記錄, 保留表的結構)

TRUNCATE 表名;

三.查詢語句 (SELECT) 部分

SELECT欄位名1, 欄位名2, …… FROM 表名1, [表名2, ……] WHERE 條件;

欄位名可以帶入函式
例如: COUNT(*), MIN(欄位名), MAX(欄位名), AVG(欄位名), DISTINCT(欄位名),
TO_CHAR(DATE欄位名,'YYYY-MM-DD HH24:MI:SS')

NVL(EXPR1, EXPR2)函式
解釋:
IF EXPR1=NULL
RETURN EXPR2
ELSE
RETURN EXPR1

DECODE(AA﹐V1﹐R1﹐V2﹐R2....)函式
解釋:
IF AA=V1 THEN RETURN R1
IF AA=V2 THEN RETURN R2
..… ELSE
RETURN NULL

LPAD(char1,n,char2)函式
解釋:
字元char1按制定的位數n顯示,不足的位數用char2字串替換左邊的空位

欄位名之間可以進行算術運算
例如: (欄位名1*欄位名1)/3

查詢語句可以巢狀
例如: SELECT …… FROM
(SELECT …… FROM表名1, [表名2, ……] WHERE 條件) WHERE 條件2;

兩個查詢語句的結果可以做集合操作
例如: 並集UNION(去掉重複記錄), 並集UNION ALL(不去掉重複記錄), 差集MINUS, 交集INTERSECT

分組查詢
SELECT欄位名1, 欄位名2, …… FROM 表名1, [表名2, ……] GROUP BY欄位名1
[HAVING 條件] ;

兩個以上表之間的連線查詢

SELECT欄位名1, 欄位名2, …… FROM 表名1, [表名2, ……] WHERE
表名1.欄位名 = 表名2. 欄位名 [ AND ……] ;

SELECT欄位名1, 欄位名2, …… FROM 表名1, [表名2, ……] WHERE
表名1.欄位名 = 表名2. 欄位名(+) [ AND ……] ;

有(+)號的欄位位置自動補空值

查詢結果集的排序操作, 預設的排序是升序ASC, 降序是DESC

SELECT欄位名1, 欄位名2, …… FROM 表名1, [表名2, ……]
ORDER BY欄位名1, 欄位名2 DESC;

字串模糊比較的方法

INSTR(欄位名, ‘字串’)>0
欄位名 LIKE ‘字串%’ [‘%字串%’]

每個表都有一個隱含的欄位ROWID, 它標記著記錄的唯一性.

四.ORACLE裡常用的資料物件 (SCHEMA)

1.索引 (INDEX)

CREATE INDEX 索引名ON 表名 ( 欄位1, [欄位2, ……] );
ALTER INDEX 索引名 REBUILD;

一個表的索引最好不要超過三個 (特殊的大表除外), 最好用單欄位索引, 結合SQL語句的分析執行情況,
也可以建立多欄位的組合索引和基於函式的索引

ORACLE8.1.7字串可以索引的最大長度為1578 單位元組
ORACLE8.0.6字串可以索引的最大長度為758 單位元組

2.檢視 (VIEW)

CREATE VIEW 檢視名AS SELECT …. FROM …..;
ALTER VIEW檢視名 COMPILE;

檢視僅是一個SQL查詢語句, 它可以把表之間複雜的關係簡潔化.

3.同義詞 (SYNONMY)
CREATE SYNONYM同義詞名FOR 表名;
CREATE SYNONYM同義詞名FOR 表名@資料庫連結名;

4.資料庫連結 (DATABASE LINK)
CREATE DATABASE LINK資料庫連結名CONNECT TO 使用者名稱 IDENTIFIED BY 密碼 USING ‘資料庫連線字串’;

資料庫連線字串可以用NET8 EASY CONFIG或者直接修改TNSNAMES.ORA裡定義.

資料庫引數global_name=true時要求資料庫連結名稱跟遠端資料庫名稱一樣

資料庫全域性名稱可以用以下命令查出
SELECT * FROM GLOBAL_NAME;

查詢遠端資料庫裡的表
SELECT …… FROM 表名@資料庫連結名;

五.許可權管理 (DCL) 語句

1.GRANT 賦於許可權
常用的系統許可權集合有以下三個:
CONNECT(基本的連線), RESOURCE(程式開發), DBA(資料庫管理)

常用的資料物件許可權有以下五個:
ALL ON 資料物件名, SELECT ON 資料物件名, UPDATE ON 資料物件名,
DELETE ON 資料物件名, INSERT ON 資料物件名, ALTER ON 資料物件名

GRANT CONNECT, RESOURCE TO 使用者名稱;
GRANT SELECT ON 表名 TO 使用者名稱;
GRANT SELECT, INSERT, DELETE ON表名 TO 使用者名稱1, 使用者名稱2;

2.REVOKE 回收許可權

REVOKE CONNECT, RESOURCE FROM 使用者名稱;
REVOKE SELECT ON 表名 FROM 使用者名稱;
REVOKE SELECT, INSERT, DELETE ON表名 FROM 使用者名稱1, 使用者名稱2;

查詢資料庫中第63號錯誤:
select orgaddr,destaddr from sm_histable0116 where error_code='63';

查詢資料庫中開戶使用者最大提交和最大下發數: select MSISDN,TCOS,OCOS from ms_usertable;

查詢資料庫中各種錯誤程式碼的總和:
select error_code,count(*) from sm_histable0513 group by error_code order
by error_code;

查詢報表資料庫中話單統計種類查詢。
select sum(Successcount) from tbl_MiddleMt0411 where ServiceType2=111
select sum(successcount),servicetype from tbl_middlemt0411 group by servicetype

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

相關文章