Oracle 總結

wonth發表於2007-06-28

/*============================================================================
 *Author: MartriWang@gmail.com
 *Date:  09/05/2007
 *Description:ORACLE Summary
 *==========================================================================*/

彙總:
set autotrace on
set autotrace traceonly explain
set timing on

或通過SQL*PLUS trace,然後檢視user_dump_dest下的跟蹤檔案,使用tkprof工具格式化後閱覽。
alter session set events '10046 trace name context forever,level 12';
alter session set events '10046 trace name context off';
SELECT p.spid,s.username FROM v$session s,v$process p WHERE s.audsid=USERENV('sessionid') AND s.paddr = p.addr;

使用方法示例:
DBserver% sqlplus perf/perf
SQL*Plus: Release 9.2.0.6.0 - Production on Mon Oct 17 14:32:29 2005
Copyright (c) 1982, 2002, Oracle Corporation. All rights reserved.
Connected to:
Oracle9i Enterprise Edition Release 9.2.0.6.0 - 64bit Production
With the Partitioning, OLAP and Oracle Data Mining options
JServer Release 9.2.0.6.0 - Production
SQL> set timing on
SQL> set autotrace on
SQL> select count(*) from perf_sdcch_nn where start_time = (select max(start_time) from perf_sdcch_nn);
COUNT(*)
----------
638
Elapsed: 00:00:00.80
Execution Plan
----------------------------------------------------------
0 SELECT STATEMENT Optimizer=CHOOSE (Cost=1 Card=1 Bytes=8)
1 0 SORT (AGGREGATE)
2 1 INDEX (RANGE SCAN) OF 'IDX02_PERF_SDCCH_NN' (NON-UNIQUE)
(Cost=2 Card=1495 Bytes=11960)

3 2 SORT (AGGREGATE)
4 3 INDEX (FULL SCAN (MIN/MAX)) OF 'IDX02_PERF_SDCCH_NN'
(NON-UNIQUE) (Cost=1 Card=3852090 Bytes=30816720)
Statistics
----------------------------------------------------------
0 recursive calls
0 db block gets
15 consistent gets
0 physical reads
0 redo size
492 bytes sent via SQL*Net to client
656 bytes received via SQL*Net from client
2 SQL*Net roundtrips to/from client
0 sorts (memory)
0 sorts (disk)
1 rows processed
SQL>
從上面的示例我們可以看到,該SQL語句執行花了0.8秒,select語句和inline view,都使用了名為'IDX02_PERF_SDCCH_NN'的索引
物理讀為0,redo log size為0,沒有生成REDO日誌。


一、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.

--MartriWang@gmail.com  10/05/2007--
create pfile='/u01/oracle/dbs/init.ora'
 from spfile='u01/oracle/dbs/Spfile.ora';
create Spfile='Spfile_name'
  FROM PFILE='pfile_name';
 
orapwd file=<filename> password=<password> entries=<max_users>

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

a、啟動ORACLE系統
hareg -y oracle

b、關閉ORACLE系統
hareg -n oracle

--MartriWang@gmail.com 22/05/2007--

--查詢、刪除重複記錄:
  法一: 用Group by語句 此查詢很快的
  
  select count(num), max(name) from student --查詢表中num列重複的,列出重複的記錄數,並列出他的name屬性
  group by num
  having count(num) >;1 --按num分組後找出表中num列重複,即出現次數大於一次
  delete from student(上面Select的)
  這樣的話就把所有重複的都刪除了。-----慎重
  
  法二:當表比較大(例如10萬條以上)時,這個方法的效率之差令人無法忍受,需要另想辦法:
  
  ---- 執行下面SQL語句後就可以顯示所有DRAWING和DSNO相同且重複的記錄
  
  SELECT * FROM EM5_PIPE_PREFAB
  WHERE ROWID!=(SELECT MAX(ROWID) FROM EM5_PIPE_PREFAB D --D相當於First,Second
  WHERE EM5_PIPE_PREFAB.DRAWING=D.DRAWING AND
  EM5_PIPE_PREFAB.DSNO=D.DSNO);
  ---- 執行下面SQL語句後就可以刪除所有DRAWING和DSNO相同且重複的記錄
  
  DELETE FROM EM5_PIPE_PREFAB
  WHERE ROWID!=(SELECT MAX(ROWID) FROM EM5_PIPE_PREFAB D
  WHERE EM5_PIPE_PREFAB.DRAWING=D.DRAWING AND
  EM5_PIPE_PREFAB.DSNO=D.DSNO);

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 owner=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、表空間的建立、刪除

--MartriWang@gmail.com 15/06/2007--
d. 刪除表列
ALTER TABLE table_name DROP COLUMN 欄位名            --del 表中欄位
1:  create table t2 as select <specific columns> from t1;  --以第一個表中的某列建立第二個新表
2:  drop table t1;                      --刪除表1
3:  rename t2 to t1;                     --把表2改名為表1

Oracle 8i及以上版本中,可以使用以下語句

 alter table 表1 drop column 列1;

六、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 單位元組

--MartriWang@gmail.com  10/05/2007--

(1)*Tree索引。

Create index indexname on tablename(columnname[columnname...])

(2)反向索引。

Create index indexname on tablename(columnname[columnname...]) reverse

(3)降序索引。

Create index indexname on tablename(columnname DESC[columnname...])

(4)點陣圖索引。

Create BITMAP index indexname on tablename(columnname[columnname...])

(5)函式索引。

Create index indexname on tablename(functionname(columnname))

注意:建立索引後分析要索引才能起作用。

analyze index indexname compute statistics;


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 ‘資料庫連線字串’;

--MartriWang@gmail.com  10/05/2007--
create database mynewdb
 user sys IDENTIFIED BY sys_id
 user system IDENTIFIED BY system_id
 LOGFILE GROUP 1 ('/u01/oracle/oradata/mynewdb/redo01.log') SIZE 100M,
   GROUP 2 ('/u01/oracle/oradata/mynewdb/redo02.log') SIZE 100M,
   GROUP 3 ('/u01/oracle/oradata/mynewdb/redo03.log') SIZE 100M
 MAXLOGFILES 5
 MAXLOGMEMBERS 5
 MAXLOGHISTORY 1
 MAXINSTANCES 100
 MAXINSTANCES 1
 CHARACTER SET US7ASCII
 NATIONAL CHARACTER SET AL16UTF16
 DATAFILE '/u01/oracle/oradata/mynewdb/system01.dbf' SIZE 325M REUSE
 EXTENT MANAGEMENT LOCAL
 SYSAUT DATAFILE '/u01/oracle/oradata/mynewdb/sysaux01.dbf' SIZE 325M REUSE
 DEFAULT TABLESPACE tbs_1
 DEFAULT TEMPORARY TABLESPACE tempts1
 TEMPFILE '/u01/oracle/oradata/mynewdb/temp01.dbf' SIZE 20M REUSE
 UNDO TABLESPACE undotbs
 DATAFILE '/u01/oracle/oradata/mynewdb/undotbs01.dbf'
  SIZE 20M REUSE AUTOEXTEND ON MAXSIZE UNLIMITED
--MartriWang@gmail.com  10/05/2007--
emctl start dbconsole
emctl stop dbconsole
--http://servername:port/em
--path:$ORACLE_HOME/install/portlist.ini
isqlplusctl start
isqlplusctl stop
--http://servername:port/isqlplus

資料庫連線字串可以用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


原文地址:http://www.cnoug.org/viewthread.php?tid=60293
//建立一個控制檔案命令到跟蹤檔案
alter database backup controlfile to trace;

//增加一個新的日誌檔案組的語句
connect internal as sysdba
alter database
add logfile group 4
(’/db01/oracle/CC1/log_1c.dbf’,
 ’/db02/oracle/CC1/log_2c.dbf’) size 5M;

alter database
add logfile member ’/db03/oracle/CC1/log_3c.dbf’
to group 4;
//在Server Manager上MOUNT並開啟一個資料庫:
connect internal as sysdba
startup mount ORA1 exclusive;
alter database open;

//生成資料字典
@catalog
@catproc

//在init.ora 中備份資料庫的位置
log_archive_dest_1 = ’/db00/arch’
log_archive_dest_state_1 = enable
log_archive_dest_2 = "service=stby.world mandatory reopen=60"
log_archive_dest_state_2 = enable
//對使用者的表空間的指定和管理相關的語句
create user USERNAME identified by PASSWORD
default tablespace TABLESPACE_NAME;
alter user USERNAME default tablespace TABLESPACE_NAME;
alter user SYSTEM quota 0 on SYSTEM;
alter user SYSTEM quota 50M on TOOLS;
create user USERNAME identified by PASSWORD
default tablespace DATA
temporary tablespace TEMP;
alter user USERNAME temporary tablespace TEMP;

//重新指定一個資料檔案的大小 :
alter database
datafile ’/db05/oracle/CC1/data01.dbf’ resize 200M;

//建立一個自動擴充套件的資料檔案:
create tablespace DATA
datafile ’/db05/oracle/CC1/data01.dbf’ size 200M
autoextend ON
next 10M
maxsize 250M;

//在表空間上增加一個自動擴充套件的資料檔案:
alter tablespace DATA
add datafile ’/db05/oracle/CC1/data02.dbf’
size 50M
autoextend ON
maxsize 300M;

//修改引數:
alter database
datafile ’/db05/oracle/CC1/data01.dbf’
autoextend ON
maxsize 300M;

//在資料檔案移動期間重新命名:
alter database rename file
 ’/db01/oracle/CC1/data01.dbf’ to
 ’/db02/oracle/CC1/data01.dbf’;

alter tablespace DATA rename datafile
 ’/db01/oracle/CC1/data01.dbf’ to
 ’/db02/oracle/CC1/data01.dbf’;

alter database rename file 
 ’/db05/oracle/CC1/redo01CC1.dbf’ to
 ’/db02/oracle/CC1/redo01CC1.dbf’;

alter database datafile ’/db05/oracle/CC1/data01.dbf’ 
resize 80M;

//建立和使用角色:
create role APPLICATION_USER;
grant CREATE SESSION to APPLICATION_USER;
grant APPLICATION_USER to username;

 //回滾段的管理
create rollback segment SEGMENT_NAME
tablespace RBS;

alter rollback segment SEGMENT_NAME offline;

drop rollback segment SEGMENT_NAME;

alter rollback segment SEGMENT_NAME online;
//回滾段上指定事務
commit;
set transaction use rollback segment ROLL_BATCH;
insert into TABLE_NAME
select * from DATA_LOAD_TABLE;
commit;

//查詢回滾段的 大小和優化引數
select * from DBA_SEGMENTS
 where Segment_Type = ’ROLLBACK’;
select N.Name,         /* rollback segment name */
       S.OptSize       /* rollback segment OPTIMAL size */
from V$ROLLNAME N, V$ROLLSTAT S
where N.USN=S.USN;

//回收回滾段
alter rollback segment R1 shrink to 15M;
alter rollback segment R1 shrink;

//例子
set transaction use rollback segment SEGMENT_NAME

alter tablespace RBS
default storage
(initial 125K next 125K minextents 18 maxextents 249)

create rollback segment R4 tablespace RBS
   storage (optimal 2250K);
alter rollback segment R4 online;

select Sessions_Highwater from V$LICENSE;
grant select on EMPLOYEE to PUBLIC;

//使用者和角色 
create role ACCOUNT_CREATOR;
grant CREATE SESSION, CREATE USER, ALTER USER 
   to ACCOUNT_CREATOR;

alter user THUMPER default role NONE;
alter user THUMPER default role CONNECT;
alter user THUMPER default role all except ACCOUNT_CREATOR;

alter profile DEFAULT
limit idle_time 60;

create profile LIMITED_PROFILE limit
FAILED_LOGIN_ATTEMPTS 5;
create user JANE identified by EYRE
profile LIMITED_PROFILE;
grant CREATE SESSION to JANE;

alter user JANE account unlock;
alter user JANE account lock;

alter profile LIMITED_PROFILE limit
PASSWORD_LIFE_TIME 30;

alter user jane password expire;

//建立作業系統使用者
REM  Creating OPS$ accounts
create user OPS$FARMER
identified by SOME_PASSWORD
default tablespace USERS
temporary tablespace TEMP;

REM  Using identified externally
create user OPS$FARMER
identified externally
default tablespace USERS
temporary tablespace TEMP;

//執行ORAPWD
ORAPWD FILE=filename PASSWORD=password ENTRIES=max_users

create role APPLICATION_USER;
grant CREATE SESSION to APPLICATION_USER;
create role DATA_ENTRY_CLERK;
grant select, insert on THUMPER.EMPLOYEE to DATA_ENTRY_CLERK;
grant select, insert on THUMPER.TIME_CARDS to DATA_ENTRY_CLERK;
grant select, insert on THUMPER.DEPARTMENT to DATA_ENTRY_CLERK;
grant APPLICATION_USER to DATA_ENTRY_CLERK;
grant DATA_ENTRY_CLERK to MCGREGOR;
grant DATA_ENTRY_CLERK to BPOTTER with admin option;

//設定角色
set role DATA_ENTRY_CLERK;
set role NONE;

//回收權利:
revoke delete on EMPLOYEE from PETER;
revoke all on EMPLOYEE from MCGREGOR;

//回收角色:
revoke ACCOUNT_CREATOR from HELPDESK;

drop user USERNAME cascade;

grant SELECT on EMPLOYEE to MCGREGOR with grant option;
grant SELECT on THUMPER.EMPLOYEE to BPOTTER with grant option;
revoke SELECT on EMPLOYEE from MCGREGOR;

create user MCGREGOR identified by VALUES ’1A2DD3CCEE354DFA’;

alter user OPS$FARMER identified by VALUES ’no way’;

//備份與恢復
使用 export 程式
exp system/manager file=expdat.dmp compress=Y owner=(HR,THUMPER)
exp system/manager file=hr.dmp owner=HR indexes=Y compress=Y
imp system/manager file=hr.dmp full=Y buffer=64000 commit=Y

--MartriWang@gmail.com 14/05/2007--
 1 將資料庫TEST完全匯出,使用者名稱system 密碼manager 匯出到D:/daochu.dmp中
   exp system/manager@TEST file=d:/daochu.dmp full=y
 2 將資料庫中system使用者與sys使用者的表匯出
   exp system/manager@TEST file=d:/daochu.dmp owner=(system,sys)
 3 將資料庫中的表table1 、table2匯出
   exp system/manager@TEST file=d:/daochu.dmp tables=(table1,table2)
 4 將資料庫中的表table1中的欄位filed1以"00"打頭的資料匯出
   exp system/manager@TEST file=d:/daochu.dmp tables=(table1) query=/" where filed1 like '00%'/"

--MartriWang@gmail.com 14/05/2007--
 1 將資料庫TEST完全匯出,使用者名稱system 密碼manager 匯出到D:/daochu.dmp中
   exp system/manager@TEST file=d:/daochu.dmp full=y
 2 將資料庫中system使用者與sys使用者的表匯出
   exp system/manager@TEST file=d:/daochu.dmp owner=(system,sys)
 3 將資料庫中的表table1 、table2匯出
   exp system/manager@TEST file=d:/daochu.dmp tables=(table1,table2)
 4 將資料庫中的表table1中的欄位filed1以"00"打頭的資料匯出
   exp system/manager@TEST file=d:/daochu.dmp tables=(table1) query=/" where filed1 like '00%'/"
  
//備份表
exp system/manager FILE=expdat.dmp TABLES=(Thumper.SALES)
//備份分割槽
exp system/manager FILE=expdat.dmp TABLES=(Thumper.SALES:Part1)

//輸入例子
imp system/manager file=expdat.dmp
imp system/manager file=expdat.dmp buffer=64000 commit=Y

exp system/manager file=thumper.dat owner=thumper grants=N
  indexes=Y compress=Y rows=Y
imp system/manager file=thumper.dat FROMUSER=thumper TOUSER=flower
      rows=Y indexes=Y
imp system/manager file=expdat.dmp full=Y commit=Y buffer=64000
imp system/manager file=expdat.dmp ignore=N rows=N commit=Y buffer=64000

//使用作業系統備份命令
REM  TAR examples
tar -cvf /dev/rmt/0hc /db0[1-9]/oracle/CC1
tar -rvf /dev/rmt/0hc /orasw/app/oracle/CC1/pfile/initcc1.ora
tar -rvf /dev/rmt/0hc /db0[1-9]/oracle/CC1 /orasw/app/oracle/CC1/pfile/initcc1.ora

//離線備份的shell指令碼
ORACLE_SID=cc1; export ORACLE_SID
ORAENV_ASK=NO; export ORAENV_ASK
. oraenv
svrmgrl <<EOF1
connect internal as sysdba
shutdown immediate;
exit
EOF1
insert backup commands like the "tar" commands here
svrmgrl <<EOF2
connect internal as sysdba
startup
EOF2

//在Server Manager上設定為archivelog mode:
connect internal as sysdba
startup mount cc1;
alter database archivelog;
archive log start;
alter database open;
archive log list
alter system set LOG_ARCHIVE_DEST_1='LOCATION=/oracle/oradata/szdb/archive';  
alter system set log_archive_format='%t_%s.dbf' scope=spfile;
alter system set log_archive_start=true scope=spfile;


//在Server Manager上設定為archivelog mode:
connect internal as sysdba
startup mount cc1;
alter database noarchivelog;
alter database open;
archive log list

select Name,
       Value
  from V$PARAMETER
 where Name like ’log_archive%’;

//聯機備份的指令碼
#
# Sample Hot Backup Script for a UNIX File System database
#
# Set up environment variables:
ORACLE_SID=cc1; export ORACLE_SID
ORAENV_ASK=NO; export ORAENV_ASK
. oraenv
svrmgrl <<EOFarch1
connect internal as sysdba
REM
REM   備份 SYSTEM tablespace
REM
alter tablespace SYSTEM begin backup;
!tar -cvf /dev/rmt/0hc /db01/oracle/CC1/sys01.dbf
alter tablespace SYSTEM end backup;
REM
REM  The SYSTEM tablespace has now been written to a
REM   tar saveset on the tape device /dev/rmt/0hc.  The
REM   rest of the tars must use the "-rvf" clause to append
REM   to that saveset.
REM
REM   備份  RBS tablespace
REM
alter tablespace RBS begin backup;
!tar -rvf /dev/rmt/0hc /db02/oracle/CC1/rbs01.dbf
alter tablespace RBS end backup;
REM
REM   備份  DATA tablespace
REM   For the purposes of this example, this tablespace
REM   will contain two files, data01.dbf and data02.dbf.
REM   The * wildcard will be used in the filename.
REM
alter tablespace DATA begin backup;
!tar -rvf /dev/rmt/0hc /db03/oracle/CC1/data0*.dbf
alter tablespace DATA end backup;
REM
REM   備份 INDEXES tablespace
REM
alter tablespace INDEXES begin backup;
!tar -rvf /dev/rmt/0hc /db04/oracle/CC1/indexes01.dbf
alter tablespace INDEXES end backup;
REM
REM   備份  TEMP tablespace
REM
alter tablespace TEMP begin backup;
!tar -rvf /dev/rmt/0hc /db05/oracle/CC1/temp01.dbf
alter tablespace TEMP end backup;
REM
REM   Follow the same pattern to back up the rest
REM   of the tablespaces.
REM
REM    
REM  Step 2.  備份歸檔日誌檔案.
archive log stop
REM
REM   Exit Server Manager, using the indicator set earlier.
exit
EOFarch1
#
#  Record which files are in the destination directory.
#     Do this by setting an environment variable that is
#  equal to the directory listing for the destination 
#  directory.
#  For this example, the log_archive_dest is 
#  /db01/oracle/arch/CC1.
#
FILES=`ls /db01/oracle/arch/CC1/arch*.dbf`; export FILES
#
#  Now go back into Server Manager and restart the
#  archiving process.  Set an indicator (called EOFarch2
#  in this example).
#
svrmgrl <<EOFarch2
connect internal
archive log start;
exit
EOFarch2
#
#  Now back up the archived redo logs to the tape
#  device via the "tar" command, then delete them
#  from the destination device via the "rm" command.
#  You may choose to compress them instead.
#
tar -rvf /dev/rmt/0hc $FILES
rm -f $FILES
#
#     Step 3.  備份控制檔案到磁碟.
#
svrmgrl <<EOFarch3
connect internal
alter database backup controlfile to
   ’db01/oracle/CC1/CC1controlfile.bck’;
exit
EOFarch3
#
#  備份控制檔案到磁帶.
#
tar -rvf /dev/rmt/0hc /db01/oracle/CC1/CC1controlfile.bck
#
#  End of hot backup script.
//自動生成開始備份的指令碼
set pagesize 0 feedback off
select 
    ’alter tablespace ’||Tablespace_Name||’ begin backup;’
  from DBA_TABLESPACES
 where Status <> ’INVALID’
spool alter_begin.sql
/
spool off

//自動生成備份結束的指令碼
set pagesize 0 feedback off
select 
    ’alter tablespace ’||Tablespace_Name||’ end backup;’
  from DBA_TABLESPACES
 where Status <> ’INVALID’
spool alter_end.sql
/
spool off

//備份歸檔日誌檔案的指令碼.
REM  See text for alternatives.
#     Step 1: Stop the archiving process. This will keep
#     additional archived redo log files from being written
#     to the destination directory during this process.
#
svrmgrl <<EOFarch1
connect internal as sysdba
archive log stop;
REM
REM   Exit Server Manager using the indicator set earlier.
exit
EOFarch1
#
#     Step 2: Record which files are in the destination 
#  directory.
#     Do this by setting an environment variable that is
#  equal to the directory listing for the destination 
#  directory.
#  For this example, the log_archive_dest is
#  /db01/oracle/arch/CC1.
#
FILES=`ls /db01/oracle/arch/CC1/arch*.dbf`; export FILES
#
#     Step 3: Go back into Server Manager and restart the
#  archiving process. Set an indicator (called EOFarch2
#  in this example).
#
svrmgrl <<EOFarch2
connect internal as sysdba
archive log start;
exit
EOFarch2
#
#     Step 4. Back up the archived redo logs to the tape
#  device via the "tar" command, then delete them
#  from the destination device via the "rm" command.
#
tar -rvf /dev/rmt/0hc $FILES
#
#     Step 5. Delete those files from the destination directory.
#
rm -f $FILES
#
#     End of archived redo log file backup script.

REM  磁碟到磁碟的備份
REM
REM   Back up the RBS tablespace - to another disk (UNIX)
REM
alter tablespace RBS begin backup;
!cp /db02/oracle/CC1/rbs01.dbf /db10/oracle/CC1/backups
alter tablespace RBS end backup;
REM

REM  移動歸檔日誌檔案的shell指令碼
#
# Procedure for moving archived redo logs to another device
#
svrmgrl <<EOFarch2
connect internal as sysdba
archive log stop;
!mv /db01/oracle/arch/CC1 /db10/oracle/arch/CC1
archive log start;
exit
EOFarch2
#
# end of archived redo log directory move.

//生成建立控制檔案命令
alter database backup controlfile to trace;

//時間點恢復的例子
connect internal as sysdba
startup mount instance_name;
recover database until time ’1999-08-07:14:40:00’;

//建立恢復目錄
rman rcvcat rman/rman@<database_service_name>

// 在(UNIX)下建立恢復目錄
RMAN> create catalog tablespace rcvcat;

// 在(NT)下建立恢復目錄
RMAN> create catalog tablespace "RCVCAT";

//連線描述符範例 
(DESCRIPTION=
      (ADDRESS=
            (PROTOCOL=TCP)
            (HOST=HQ)
            (PORT=1521))
      (CONNECT DATA=
            (SID=loc)))

// listener.ora 的條目entry
// listener.ora 的條目entry
LISTENER =
(ADDRESS_LIST =
(ADDRESS=
(PROTOCOL=IPC)
(KEY= loc.world)
)
)
SID_LIST_LISTENER =
(SID_LIST =
(SID_DESC =
(SID_NAME = loc)
(ORACLE_HOME = /orasw/app/oracle/product/8.1.5.1)
)
)

// tnsnames.ora 的條目
LOC=
(DESCRIPTION=
(ADDRESS =
(PROTOCOL = TCP)
(HOST = HQ)
(PORT = 1521))
)
(CONNECT_DATA =
(SERVICE_NAME = loc)
(INSTANCE_NAME = loc)
)
)

//連線引數的設定(sql*net)
LOC =(DESCRIPTION=
(ADDRESS=
(COMMUNITY=TCP.HQ.COMPANY)
(PROTOCOL=TCP)
(HOST=HQ)
(PORT=1521))
(CONNECT DATA=
(SID=loc)))
//引數檔案配置範例
// tnsnames.ora
HQ =(DESCRIPTION=
(ADDRESS=
(PROTOCOL=TCP)
(HOST=HQ)
(PORT=1521))
(CONNECT DATA=
(SID=loc)))

// listener.ora
LISTENER =
(ADDRESS_LIST =
(ADDRESS=
(PROTOCOL=IPC)
(KEY= loc)
)
)
SID_LIST_LISTENER =
(SID_LIST =
(SID_DESC =
(SID_NAME = loc)
(ORACLE_HOME = /orasw/app/oracle/product/8.1.5.1)
)
)

// Oracle8I tnsnames.ora
LOC=
(DESCRIPTION=
(ADDRESS =
(PROTOCOL = TCP)
(HOST = HQ)
(PORT = 1521))
)
(CONNECT_DATA =
(SERVICE_NAME = loc)
(INSTANCE_NAME = loc)
)
)

//使用 COPY 實現資料庫之間的複製
copy from
remote_username/remote_password@service_name
to
username/password@service_name
[append|create|insert|replace]
TABLE_NAME
using subquery;

REM COPY example
set copycommit 1
set arraysize 1000
copy from HR/PUFFINSTUFF@loc -
create EMPLOYEE -
using -
select * from EMPLOYEE


//監視器的管理
lsnrctl start
lsnrctl start my_lsnr
lsnrctl status
lsnrctl status hq

檢查監視器的程式
ps -ef | grep tnslsnr
//在 lsnrctl 內停止監視器
set password lsnr_password
stop

//在lsnrctl 內列出所有的服務
set password lsnr_password
services
//啟動或停止一個NT的listener
net start Oracle<version_name>TNSListener
net stop Oracle<version_name>TNSListener

// tnsnames.ora 檔案的內容
fld1 =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)
(HOST = server1.fld.com)(PORT = 1521))
)
(CONNECT_DATA =
(SID = fld1)
)
)
//作業系統網路的管理

telnet host_name
ping host_name
/etc/hosts 檔案
130.110.238.109 nmhost
130.110.238.101 txhost
130.110.238.102 azhost arizona
//oratab 表項
loc:/orasw/app/oracle/product/8.1.5.1:Y
cc1:/orasw/app/oracle/product/8.1.5.1:N
old:/orasw/app/oracle/product/8.1.5.0:Y

//建立一個控制檔案命令到跟蹤檔案
alter database backup controlfile to trace;

//增加一個新的日誌檔案組的語句
connect internal as sysdba
alter database
add logfile group 4
(’/db01/oracle/CC1/log_1c.dbf’,
 ’/db02/oracle/CC1/log_2c.dbf’) size 5M;

alter database
add logfile member ’/db03/oracle/CC1/log_3c.dbf’
to group 4;
//在Server Manager上MOUNT並開啟一個資料庫:
connect internal as sysdba
startup mount ORA1 exclusive;
alter database open;

//生成資料字典
@catalog
@catproc

//在init.ora 中備份資料庫的位置
log_archive_dest_1 = ’/db00/arch’
log_archive_dest_state_1 = enable
log_archive_dest_2 = "service=stby.world mandatory reopen=60"
log_archive_dest_state_2 = enable
//對使用者的表空間的指定和管理相關的語句
create user USERNAME identified by PASSWORD
default tablespace TABLESPACE_NAME;
alter user USERNAME default tablespace TABLESPACE_NAME;
alter user SYSTEM quota 0 on SYSTEM;
alter user SYSTEM quota 50M on TOOLS;
create user USERNAME identified by PASSWORD
default tablespace DATA
temporary tablespace TEMP;
alter user USERNAME temporary tablespace TEMP;

//重新指定一個資料檔案的大小 :
alter database
datafile ’/db05/oracle/CC1/data01.dbf’ resize 200M;

//建立一個自動擴充套件的資料檔案:
create tablespace DATA
datafile ’/db05/oracle/CC1/data01.dbf’ size 200M
autoextend ON
next 10M
maxsize 250M;

//在表空間上增加一個自動擴充套件的資料檔案:
alter tablespace DATA
add datafile ’/db05/oracle/CC1/data02.dbf’
size 50M
autoextend ON
maxsize 300M;

//修改引數:
alter database
datafile ’/db05/oracle/CC1/data01.dbf’
autoextend ON
maxsize 300M;

//在資料檔案移動期間重新命名:
alter database rename file
 ’/db01/oracle/CC1/data01.dbf’ to
 ’/db02/oracle/CC1/data01.dbf’;

alter tablespace DATA rename datafile
 ’/db01/oracle/CC1/data01.dbf’ to
 ’/db02/oracle/CC1/data01.dbf’;

alter database rename file 
 ’/db05/oracle/CC1/redo01CC1.dbf’ to
 ’/db02/oracle/CC1/redo01CC1.dbf’;

alter database datafile ’/db05/oracle/CC1/data01.dbf’ 
resize 80M;

//建立和使用角色:
create role APPLICATION_USER;
grant CREATE SESSION to APPLICATION_USER;
grant APPLICATION_USER to username;

 //回滾段的管理
create rollback segment SEGMENT_NAME
tablespace RBS;

alter rollback segment SEGMENT_NAME offline;

drop rollback segment SEGMENT_NAME;

alter rollback segment SEGMENT_NAME online;
//回滾段上指定事務
commit;
set transaction use rollback segment ROLL_BATCH;
insert into TABLE_NAME
select * from DATA_LOAD_TABLE;
commit;

//查詢回滾段的 大小和優化引數
select * from DBA_SEGMENTS
 where Segment_Type = ’ROLLBACK’;
select N.Name,         /* rollback segment name */
       S.OptSize       /* rollback segment OPTIMAL size */
from V$ROLLNAME N, V$ROLLSTAT S
where N.USN=S.USN;

//回收回滾段
alter rollback segment R1 shrink to 15M;
alter rollback segment R1 shrink;

//例子
set transaction use rollback segment SEGMENT_NAME

alter tablespace RBS
default storage
(initial 125K next 125K minextents 18 maxextents 249)

create rollback segment R4 tablespace RBS
   storage (optimal 2250K);
alter rollback segment R4 online;

select Sessions_Highwater from V$LICENSE;
grant select on EMPLOYEE to PUBLIC;

//使用者和角色 
create role ACCOUNT_CREATOR;
grant CREATE SESSION, CREATE USER, ALTER USER 
   to ACCOUNT_CREATOR;

alter user THUMPER default role NONE;
alter user THUMPER default role CONNECT;
alter user THUMPER default role all except ACCOUNT_CREATOR;

alter profile DEFAULT
limit idle_time 60;

create profile LIMITED_PROFILE limit
FAILED_LOGIN_ATTEMPTS 5;
create user JANE identified by EYRE
profile LIMITED_PROFILE;
grant CREATE SESSION to JANE;

alter user JANE account unlock;
alter user JANE account lock;

alter profile LIMITED_PROFILE limit
PASSWORD_LIFE_TIME 30;

alter user jane password expire;

//建立作業系統使用者
REM  Creating OPS$ accounts
create user OPS$FARMER
identified by SOME_PASSWORD
default tablespace USERS
temporary tablespace TEMP;

REM  Using identified externally
create user OPS$FARMER
identified externally
default tablespace USERS
temporary tablespace TEMP;

//執行ORAPWD
ORAPWD FILE=filename PASSWORD=password ENTRIES=max_users

create role APPLICATION_USER;
grant CREATE SESSION to APPLICATION_USER;
create role DATA_ENTRY_CLERK;
grant select, insert on THUMPER.EMPLOYEE to DATA_ENTRY_CLERK;
grant select, insert on THUMPER.TIME_CARDS to DATA_ENTRY_CLERK;
grant select, insert on THUMPER.DEPARTMENT to DATA_ENTRY_CLERK;
grant APPLICATION_USER to DATA_ENTRY_CLERK;
grant DATA_ENTRY_CLERK to MCGREGOR;
grant DATA_ENTRY_CLERK to BPOTTER with admin option;

//設定角色
set role DATA_ENTRY_CLERK;
set role NONE;

//回收權利:
revoke delete on EMPLOYEE from PETER;
revoke all on EMPLOYEE from MCGREGOR;

//回收角色:
revoke ACCOUNT_CREATOR from HELPDESK;

drop user USERNAME cascade;

grant SELECT on EMPLOYEE to MCGREGOR with grant option;
grant SELECT on THUMPER.EMPLOYEE to BPOTTER with grant option;
revoke SELECT on EMPLOYEE from MCGREGOR;

create user MCGREGOR identified by VALUES ’1A2DD3CCEE354DFA’;

alter user OPS$FARMER identified by VALUES ’no way’;

//備份與恢復
使用 export 程式
exp system/manager file=expdat.dmp compress=Y owner=(HR,THUMPER)
exp system/manager file=hr.dmp owner=HR indexes=Y compress=Y
imp system/manager file=hr.dmp full=Y buffer=64000 commit=Y

//備份表
exp system/manager FILE=expdat.dmp TABLES=(Thumper.SALES)
//備份分割槽
exp system/manager FILE=expdat.dmp TABLES=(Thumper.SALES:Part1)

//輸入例子
imp system/manager file=expdat.dmp
imp system/manager file=expdat.dmp buffer=64000 commit=Y

exp system/manager file=thumper.dat owner=thumper grants=N
  indexes=Y compress=Y rows=Y
imp system/manager file=thumper.dat FROMUSER=thumper TOUSER=flower
      rows=Y indexes=Y
imp system/manager file=expdat.dmp full=Y commit=Y buffer=64000
imp system/manager file=expdat.dmp ignore=N rows=N commit=Y buffer=64000

//使用作業系統備份命令
REM  TAR examples
tar -cvf /dev/rmt/0hc /db0[1-9]/oracle/CC1
tar -rvf /dev/rmt/0hc /orasw/app/oracle/CC1/pfile/initcc1.ora
tar -rvf /dev/rmt/0hc /db0[1-9]/oracle/CC1 /orasw/app/oracle/CC1/pfile/initcc1.ora

//離線備份的shell指令碼
ORACLE_SID=cc1; export ORACLE_SID
ORAENV_ASK=NO; export ORAENV_ASK
. oraenv
svrmgrl <<EOF1
connect internal as sysdba
shutdown immediate;
exit
EOF1
insert backup commands like the "tar" commands here
svrmgrl <<EOF2
connect internal as sysdba
startup
EOF2

//在Server Manager上設定為archivelog mode:
connect internal as sysdba
startup mount cc1;
alter database archivelog;
archive log start;
alter database open;

//在Server Manager上設定為archivelog mode:
connect internal as sysdba
startup mount cc1;
alter database noarchivelog;
alter database open;

select Name,
       Value
  from V$PARAMETER
 where Name like ’log_archive%’;

//聯機備份的指令碼
#
# Sample Hot Backup Script for a UNIX File System database
#
# Set up environment variables:
ORACLE_SID=cc1; export ORACLE_SID
ORAENV_ASK=NO; export ORAENV_ASK
. oraenv
svrmgrl <<EOFarch1
connect internal as sysdba
REM
REM   備份 SYSTEM tablespace
REM
alter tablespace SYSTEM begin backup;
!tar -cvf /dev/rmt/0hc /db01/oracle/CC1/sys01.dbf
alter tablespace SYSTEM end backup;
REM
REM  The SYSTEM tablespace has now been written to a
REM   tar saveset on the tape device /dev/rmt/0hc.  The
REM   rest of the tars must use the "-rvf" clause to append
REM   to that saveset.
REM
REM   備份  RBS tablespace
REM
alter tablespace RBS begin backup;
!tar -rvf /dev/rmt/0hc /db02/oracle/CC1/rbs01.dbf
alter tablespace RBS end backup;
REM
REM   備份  DATA tablespace
REM   For the purposes of this example, this tablespace
REM   will contain two files, data01.dbf and data02.dbf.
REM   The * wildcard will be used in the filename.
REM
alter tablespace DATA begin backup;
!tar -rvf /dev/rmt/0hc /db03/oracle/CC1/data0*.dbf
alter tablespace DATA end backup;
REM
REM   備份 INDEXES tablespace
REM
alter tablespace INDEXES begin backup;
!tar -rvf /dev/rmt/0hc /db04/oracle/CC1/indexes01.dbf
alter tablespace INDEXES end backup;
REM
REM   備份  TEMP tablespace
REM
alter tablespace TEMP begin backup;
!tar -rvf /dev/rmt/0hc /db05/oracle/CC1/temp01.dbf
alter tablespace TEMP end backup;
REM
REM   Follow the same pattern to back up the rest
REM   of the tablespaces.
REM
REM    
REM  Step 2.  備份歸檔日誌檔案.
archive log stop
REM
REM   Exit Server Manager, using the indicator set earlier.
exit
EOFarch1
#
#  Record which files are in the destination directory.
#     Do this by setting an environment variable that is
#  equal to the directory listing for the destination 
#  directory.
#  For this example, the log_archive_dest is 
#  /db01/oracle/arch/CC1.
#
FILES=`ls /db01/oracle/arch/CC1/arch*.dbf`; export FILES
#
#  Now go back into Server Manager and restart the
#  archiving process.  Set an indicator (called EOFarch2
#  in this example).
#
svrmgrl <<EOFarch2
connect internal
archive log start;
exit
EOFarch2
#
#  Now back up the archived redo logs to the tape
#  device via the "tar" command, then delete them
#  from the destination device via the "rm" command.
#  You may choose to compress them instead.
#
tar -rvf /dev/rmt/0hc $FILES
rm -f $FILES
#
#     Step 3.  備份控制檔案到磁碟.
#
svrmgrl <<EOFarch3
connect internal
alter database backup controlfile to
   ’db01/oracle/CC1/CC1controlfile.bck’;
exit
EOFarch3
#
#  備份控制檔案到磁帶.
#
tar -rvf /dev/rmt/0hc /db01/oracle/CC1/CC1controlfile.bck
#
#  End of hot backup script.
//自動生成開始備份的指令碼
set pagesize 0 feedback off
select 
    ’alter tablespace ’||Tablespace_Name||’ begin backup;’
  from DBA_TABLESPACES
 where Status <> ’INVALID’
spool alter_begin.sql
/
spool off

//自動生成備份結束的指令碼
set pagesize 0 feedback off
select 
    ’alter tablespace ’||Tablespace_Name||’ end backup;’
  from DBA_TABLESPACES
 where Status <> ’INVALID’
spool alter_end.sql
/
spool off

//備份歸檔日誌檔案的指令碼.
REM  See text for alternatives.
#     Step 1: Stop the archiving process. This will keep
#     additional archived redo log files from being written
#     to the destination directory during this process.
#
svrmgrl <<EOFarch1
connect internal as sysdba
archive log stop;
REM
REM   Exit Server Manager using the indicator set earlier.
exit
EOFarch1
#
#     Step 2: Record which files are in the destination 
#  directory.
#     Do this by setting an environment variable that is
#  equal to the directory listing for the destination 
#  directory.
#  For this example, the log_archive_dest is
#  /db01/oracle/arch/CC1.
#
FILES=`ls /db01/oracle/arch/CC1/arch*.dbf`; export FILES
#
#     Step 3: Go back into Server Manager and restart the
#  archiving process. Set an indicator (called EOFarch2
#  in this example).
#
svrmgrl <<EOFarch2
connect internal as sysdba
archive log start;
exit
EOFarch2
#
#     Step 4. Back up the archived redo logs to the tape
#  device via the "tar" command, then delete them
#  from the destination device via the "rm" command.
#
tar -rvf /dev/rmt/0hc $FILES
#
#     Step 5. Delete those files from the destination directory.
#
rm -f $FILES
#
#     End of archived redo log file backup script.

REM  磁碟到磁碟的備份
REM
REM   Back up the RBS tablespace - to another disk (UNIX)
REM
alter tablespace RBS begin backup;
!cp /db02/oracle/CC1/rbs01.dbf /db10/oracle/CC1/backups
alter tablespace RBS end backup;
REM

REM  移動歸檔日誌檔案的shell指令碼
#
# Procedure for moving archived redo logs to another device
#
svrmgrl <<EOFarch2
connect internal as sysdba
archive log stop;
!mv /db01/oracle/arch/CC1 /db10/oracle/arch/CC1
archive log start;
exit
EOFarch2
#
# end of archived redo log directory move.

//生成建立控制檔案命令
alter database backup controlfile to trace;

//時間點恢復的例子
connect internal as sysdba
startup mount instance_name;
recover database until time ’1999-08-07:14:40:00’;

//建立恢復目錄
rman rcvcat rman/rman@<database_service_name>

// 在(UNIX)下建立恢復目錄
RMAN> create catalog tablespace rcvcat;

// 在(NT)下建立恢復目錄
RMAN> create catalog tablespace "RCVCAT";

//連線描述符範例 
(DESCRIPTION=
      (ADDRESS=
            (PROTOCOL=TCP)
            (HOST=HQ)
            (PORT=1521))
      (CONNECT DATA=
            (SID=loc)))

// listener.ora 的條目entry


//建立一個控制檔案命令到跟蹤檔案
alter database backup controlfile to trace;

//增加一個新的日誌檔案組的語句
connect internal as sysdba
alter database
add logfile group 4
(’/db01/oracle/CC1/log_1c.dbf’,
’/db02/oracle/CC1/log_2c.dbf’) size 5M;

alter database
add logfile member ’/db03/oracle/CC1/log_3c.dbf’
to group 4;
//在Server Manager上MOUNT並開啟一個資料庫:
connect internal as sysdba
startup mount ORA1 exclusive;
alter database open;

//生成資料字典
@catalog
@catproc

//在init.ora 中備份資料庫的位置
log_archive_dest_1 = ’/db00/arch’
log_archive_dest_state_1 = enable
log_archive_dest_2 = "service=stby.world mandatory reopen=60"
log_archive_dest_state_2 = enable
//對使用者的表空間的指定和管理相關的語句
create user USERNAME identified by PASSWORD
default tablespace TABLESPACE_NAME;
alter user USERNAME default tablespace TABLESPACE_NAME;
alter user SYSTEM quota 0 on SYSTEM;
alter user SYSTEM quota 50M on TOOLS;
create user USERNAME identified by PASSWORD
default tablespace DATA
temporary tablespace TEMP;
alter user USERNAME temporary tablespace TEMP;

//重新指定一個資料檔案的大小 :
alter database
datafile ’/db05/oracle/CC1/data01.dbf’ resize 200M;

//建立一個自動擴充套件的資料檔案:
create tablespace DATA
datafile ’/db05/oracle/CC1/data01.dbf’ size 200M
autoextend ON
next 10M
maxsize 250M;

//在表空間上增加一個自動擴充套件的資料檔案:
alter tablespace DATA
add datafile ’/db05/oracle/CC1/data02.dbf’
size 50M
autoextend ON
maxsize 300M;

//修改引數:
alter database
datafile ’/db05/oracle/CC1/data01.dbf’
autoextend ON
maxsize 300M;

//在資料檔案移動期間重新命名:
alter database rename file
 ’/db01/oracle/CC1/data01.dbf’ to
 ’/db02/oracle/CC1/data01.dbf’;

alter tablespace DATA rename datafile
 ’/db01/oracle/CC1/data01.dbf’ to
 ’/db02/oracle/CC1/data01.dbf’;

alter database rename file 
 ’/db05/oracle/CC1/redo01CC1.dbf’ to
 ’/db02/oracle/CC1/redo01CC1.dbf’;

alter database datafile ’/db05/oracle/CC1/data01.dbf’ 
resize 80M;
//建立和使用角色:
create role APPLICATION_USER;
grant CREATE SESSION to APPLICATION_USER;
grant APPLICATION_USER to username;

 //回滾段的管理
create rollback segment SEGMENT_NAME
tablespace RBS;

alter rollback segment SEGMENT_NAME offline;

drop rollback segment SEGMENT_NAME;

alter rollback segment SEGMENT_NAME online;
//回滾段上指定事務
commit;
set transaction use rollback segment ROLL_BATCH;
insert into TABLE_NAME
select * from DATA_LOAD_TABLE;
commit;

//查詢回滾段的 大小和優化引數
select * from DBA_SEGMENTS
 where Segment_Type = ’ROLLBACK’;
select N.Name,         /* rollback segment name */
       S.OptSize       /* rollback segment OPTIMAL size */
from V$ROLLNAME N, V$ROLLSTAT S
where N.USN=S.USN;

//回收回滾段
alter rollback segment R1 shrink to 15M;
alter rollback segment R1 shrink;

//例子
set transaction use rollback segment SEGMENT_NAME

alter tablespace RBS
default storage
(initial 125K next 125K minextents 18 maxextents 249)

create rollback segment R4 tablespace RBS
   storage (optimal 2250K);
alter rollback segment R4 online;

select Sessions_Highwater from V$LICENSE;
grant select on EMPLOYEE to PUBLIC;

//使用者和角色 
create role ACCOUNT_CREATOR;
grant CREATE SESSION, CREATE USER, ALTER USER 
   to ACCOUNT_CREATOR;

alter user THUMPER default role NONE;
alter user THUMPER default role CONNECT;
alter user THUMPER default role all except ACCOUNT_CREATOR;

alter profile DEFAULT
limit idle_time 60;

create profile LIMITED_PROFILE limit
FAILED_LOGIN_ATTEMPTS 5;
create user JANE identified by EYRE
profile LIMITED_PROFILE;
grant CREATE SESSION to JANE;

alter user JANE account unlock;
alter user JANE account lock;

alter profile LIMITED_PROFILE limit
PASSWORD_LIFE_TIME 30;

alter user jane password expire;

//建立作業系統使用者
REM  Creating OPS$ accounts
create user OPS$FARMER
identified by SOME_PASSWORD
default tablespace USERS
temporary tablespace TEMP;

REM  Using identified externally
create user OPS$FARMER
identified externally
default tablespace USERS
temporary tablespace TEMP;

//執行ORAPWD
ORAPWD FILE=filename PASSWORD=password ENTRIES=max_users

create role APPLICATION_USER;
grant CREATE SESSION to APPLICATION_USER;
create role DATA_ENTRY_CLERK;
grant select, insert on THUMPER.EMPLOYEE to DATA_ENTRY_CLERK;
grant select, insert on THUMPER.TIME_CARDS to DATA_ENTRY_CLERK;
grant select, insert on THUMPER.DEPARTMENT to DATA_ENTRY_CLERK;
grant APPLICATION_USER to DATA_ENTRY_CLERK;
grant DATA_ENTRY_CLERK to MCGREGOR;
grant DATA_ENTRY_CLERK to BPOTTER with admin option;

//設定角色
set role DATA_ENTRY_CLERK;
set role NONE;

//回收權利:
revoke delete on EMPLOYEE from PETER;
revoke all on EMPLOYEE from MCGREGOR;

//回收角色:
revoke ACCOUNT_CREATOR from HELPDESK;

drop user USERNAME cascade;

grant SELECT on EMPLOYEE to MCGREGOR with grant option;
grant SELECT on THUMPER.EMPLOYEE to BPOTTER with grant option;
revoke SELECT on EMPLOYEE from MCGREGOR;

create user MCGREGOR identified by VALUES ’1A2DD3CCEE354DFA’;

alter user OPS$FARMER identified by VALUES ’no way’;

//備份與恢復
使用 export 程式
exp system/manager file=expdat.dmp compress=Y owner=(HR,THUMPER)
exp system/manager file=hr.dmp owner=HR indexes=Y compress=Y
imp system/manager file=hr.dmp full=Y buffer=64000 commit=Y

//備份表
exp system/manager FILE=expdat.dmp TABLES=(Thumper.SALES)
//備份分割槽
exp system/manager FILE=expdat.dmp TABLES=(Thumper.SALES:Part1)

//輸入例子
imp system/manager file=expdat.dmp
imp system/manager file=expdat.dmp buffer=64000 commit=Y

exp system/manager file=thumper.dat owner=thumper grants=N
  indexes=Y compress=Y rows=Y
imp system/manager file=thumper.dat FROMUSER=thumper TOUSER=flower
      rows=Y indexes=Y
imp system/manager file=expdat.dmp full=Y commit=Y buffer=64000
imp system/manager file=expdat.dmp ignore=N rows=N commit=Y buffer=64000

//使用作業系統備份命令
REM  TAR examples
tar -cvf /dev/rmt/0hc /db0[1-9]/oracle/CC1
tar -rvf /dev/rmt/0hc /orasw/app/oracle/CC1/pfile/initcc1.ora
tar -rvf /dev/rmt/0hc /db0[1-9]/oracle/CC1 /orasw/app/oracle/CC1/pfile/initcc1.ora

//離線備份的shell指令碼
ORACLE_SID=cc1; export ORACLE_SID
ORAENV_ASK=NO; export ORAENV_ASK
. oraenv
svrmgrl <<EOF1
connect internal as sysdba
shutdown immediate;
exit
EOF1
insert backup commands like the "tar" commands here
svrmgrl <<EOF2
connect internal as sysdba
startup
EOF2

//在Server Manager上設定為archivelog mode:
connect internal as sysdba
startup mount cc1;
alter database archivelog;
archive log start;
alter database open;

//在Server Manager上設定為archivelog mode:
connect internal as sysdba
startup mount cc1;
alter database noarchivelog;
alter database open;

select Name,
       Value
  from V$PARAMETER
 where Name like ’log_archive%’;

//聯機備份的指令碼
#
# Sample Hot Backup Script for a UNIX File System database
#
# Set up environment variables:
ORACLE_SID=cc1; export ORACLE_SID
ORAENV_ASK=NO; export ORAENV_ASK
. oraenv
svrmgrl <<EOFarch1
connect internal as sysdba
REM
REM   備份 SYSTEM tablespace
REM
alter tablespace SYSTEM begin backup;
!tar -cvf /dev/rmt/0hc /db01/oracle/CC1/sys01.dbf
alter tablespace SYSTEM end backup;
REM
REM  The SYSTEM tablespace has now been written to a
REM   tar saveset on the tape device /dev/rmt/0hc.  The
REM   rest of the tars must use the "-rvf" clause to append
REM   to that saveset.
REM
REM   備份  RBS tablespace
REM
alter tablespace RBS begin backup;
!tar -rvf /dev/rmt/0hc /db02/oracle/CC1/rbs01.dbf
alter tablespace RBS end backup;
REM
REM   備份  DATA tablespace
REM   For the purposes of this example, this tablespace
REM   will contain two files, data01.dbf and data02.dbf.
REM   The * wildcard will be used in the filename.
REM
alter tablespace DATA begin backup;
!tar -rvf /dev/rmt/0hc /db03/oracle/CC1/data0*.dbf
alter tablespace DATA end backup;
REM
REM   備份 INDEXES tablespace
REM
alter tablespace INDEXES begin backup;
!tar -rvf /dev/rmt/0hc /db04/oracle/CC1/indexes01.dbf
alter tablespace INDEXES end backup;
REM
REM   備份  TEMP tablespace
REM
alter tablespace TEMP begin backup;
!tar -rvf /dev/rmt/0hc /db05/oracle/CC1/temp01.dbf
alter tablespace TEMP end backup;
REM
REM   Follow the same pattern to back up the rest
REM   of the tablespaces.
REM
REM    
REM  Step 2.  備份歸檔日誌檔案.
archive log stop
REM
REM   Exit Server Manager, using the indicator set earlier.
exit
EOFarch1
#
#  Record which files are in the destination directory.
#     Do this by setting an environment variable that is
#  equal to the directory listing for the destination 
#  directory.
#  For this example, the log_archive_dest is 
#  /db01/oracle/arch/CC1.
#
FILES=`ls /db01/oracle/arch/CC1/arch*.dbf`; export FILES
#
#  Now go back into Server Manager and restart the
#  archiving process.  Set an indicator (called EOFarch2
#  in this example).
#
svrmgrl <<EOFarch2
connect internal
archive log start;
exit
EOFarch2
#
#  Now back up the archived redo logs to the tape
#  device via the "tar" command, then delete them
#  from the destination device via the "rm" command.
#  You may choose to compress them instead.
#
tar -rvf /dev/rmt/0hc $FILES
rm -f $FILES
#
#     Step 3.  備份控制檔案到磁碟.
#
svrmgrl <<EOFarch3
connect internal
alter database backup controlfile to
   ’db01/oracle/CC1/CC1controlfile.bck’;
exit
EOFarch3
#
#  備份控制檔案到磁帶.
#
tar -rvf /dev/rmt/0hc /db01/oracle/CC1/CC1controlfile.bck
#
#  End of hot backup script.
//自動生成開始備份的指令碼
set pagesize 0 feedback off
select 
    ’alter tablespace ’||Tablespace_Name||’ begin backup;’
  from DBA_TABLESPACES
 where Status <> ’INVALID’
spool alter_begin.sql
/
spool off

//自動生成備份結束的指令碼
set pagesize 0 feedback off
select 
    ’alter tablespace ’||Tablespace_Name||’ end backup;’
  from DBA_TABLESPACES
 where Status <> ’INVALID’
spool alter_end.sql
/
spool off

//備份歸檔日誌檔案的指令碼.
REM  See text for alternatives.
#     Step 1: Stop the archiving process. This will keep
#     additional archived redo log files from being written
#     to the destination directory during this process.
#
svrmgrl <<EOFarch1
connect internal as sysdba
archive log stop;
REM
REM   Exit Server Manager using the indicator set earlier.
exit
EOFarch1
#
#     Step 2: Record which files are in the destination 
#  directory.
#     Do this by setting an environment variable that is
#  equal to the directory listing for the destination 
#  directory.
#  For this example, the log_archive_dest is
#  /db01/oracle/arch/CC1.
#
FILES=`ls /db01/oracle/arch/CC1/arch*.dbf`; export FILES
#
#     Step 3: Go back into Server Manager and restart the
#  archiving process. Set an indicator (called EOFarch2
#  in this example).
#
svrmgrl <<EOFarch2
connect internal as sysdba
archive log start;
exit
EOFarch2
#
#     Step 4. Back up the archived redo logs to the tape
#  device via the "tar" command, then delete them
#  from the destination device via the "rm" command.
#
tar -rvf /dev/rmt/0hc $FILES
#
#     Step 5. Delete those files from the destination directory.
#
rm -f $FILES
#
#     End of archived redo log file backup script.

REM  磁碟到磁碟的備份
REM
REM   Back up the RBS tablespace - to another disk (UNIX)
REM
alter tablespace RBS begin backup;
!cp /db02/oracle/CC1/rbs01.dbf /db10/oracle/CC1/backups
alter tablespace RBS end backup;
REM

REM  移動歸檔日誌檔案的shell指令碼
#
# Procedure for moving archived redo logs to another device
#
svrmgrl <<EOFarch2
connect internal as sysdba
archive log stop;
!mv /db01/oracle/arch/CC1 /db10/oracle/arch/CC1
archive log start;
exit
EOFarch2
#
# end of archived redo log directory move.

//生成建立控制檔案命令
alter database backup controlfile to trace;

//時間點恢復的例子
connect internal as sysdba
startup mount instance_name;
recover database until time ’1999-08-07:14:40:00’;

//建立恢復目錄
rman rcvcat rman/rman@<database_service_name>

// 在(UNIX)下建立恢復目錄
RMAN> create catalog tablespace rcvcat;

// 在(NT)下建立恢復目錄
RMAN> create catalog tablespace "RCVCAT";

//連線描述符範例 
(DESCRIPTION=
      (ADDRESS=
            (PROTOCOL=TCP)
            (HOST=HQ)
            (PORT=1521))
      (CONNECT DATA=
            (SID=loc)))

// listener.ora 的條目entry
LISTENER =
  (ADDRESS_LIST =
        (ADDRESS=
          (PROTOCOL=IPC)
轉貼於 學生大讀書網 http://
 (KEY= loc.world)
        )
   ) 
SID_LIST_LISTENER =
  (SID_LIST =
    (SID_DESC =
(SID_NAME = loc)
      (ORACLE_HOME = /orasw/app/oracle/product/8.1.5.1)
   )
 )

//  tnsnames.ora 的條目
LOC=
  (DESCRIPTION=  
   (ADDRESS =
        (PROTOCOL = TCP)
        (HOST = HQ)
        (PORT = 1521))
    )
    (CONNECT_DATA =
      (SERVICE_NAME = loc)
      (INSTANCE_NAME = loc)
    )
)

//連線引數的設定(sql*net)
LOC =(DESCRIPTION=
      (ADDRESS=
            (COMMUNITY=TCP.HQ.COMPANY)
            (PROTOCOL=TCP)
            (HOST=HQ)
            (PORT=1521))
      (CONNECT DATA=
            (SID=loc)))
//引數檔案配置範例
// tnsnames.ora 
HQ =(DESCRIPTION=
      (ADDRESS=
            (PROTOCOL=TCP)
            (HOST=HQ)
            (PORT=1521))
      (CONNECT DATA=
            (SID=loc)))

// listener.ora 
LISTENER =
  (ADDRESS_LIST =
        (ADDRESS=
          (PROTOCOL=IPC)
          (KEY= loc)
        )
   ) 
SID_LIST_LISTENER =
  (SID_LIST =
    (SID_DESC =
      (SID_NAME = loc)
      (ORACLE_HOME = /orasw/app/oracle/product/8.1.5.1)
    )
  )

// Oracle8I tnsnames.ora 
LOC=
  (DESCRIPTION=  
   (ADDRESS =
        (PROTOCOL = TCP)
        (HOST = HQ)
 (PORT = 1521))
    )
    (CONNECT_DATA =
      (SERVICE_NAME = loc)
      (INSTANCE_NAME = loc)
    )

//使用 COPY 實現資料庫之間的複製
copy from
remote_username/remote_password@service_name
to
username/password@service_name
[append|create|insert|replace]
TABLE_NAME
using subquery;

REM  COPY example
set copycommit 1
set arraysize 1000
copy from HR/PUFFINSTUFF@loc -
create EMPLOYEE -
using -
select * from EMPLOYEE


//監視器的管理
lsnrctl start
lsnrctl start my_lsnr
lsnrctl status
lsnrctl status hq

檢查監視器的程式
ps -ef | grep tnslsnr
//在 lsnrctl  內停止監視器
set password lsnr_password
stop

//在lsnrctl 內列出所有的服務
set password lsnr_password
services
//啟動或停止一個NT的listener
net start Oracle<version_name>TNSListener
net stop Oracle<version_name>TNSListener

// tnsnames.ora 檔案的內容
fld1 =
  (DESCRIPTION =
    (ADDRESS_LIST =
      (ADDRESS = (PROTOCOL = TCP)
      (HOST = server1.fld.com)(PORT = 1521))
    )
    (CONNECT_DATA =
      (SID = fld1)
    )
  )
//作業系統網路的管理

telnet host_name
ping host_name
/etc/hosts 檔案
130.110.238.109 nmhost
130.110.238.101 txhost
130.110.238.102 azhost  arizona 
//oratab 表項
loc:/orasw/app/oracle/product/8.1.5.1:Y
cc1:/orasw/app/oracle/product/8.1.5.1:N
old:/orasw/app/oracle/product/8.1.5.0:Y

--MartriWang@gmail.com  11/05/2007--
Oracle優化經典文章------索引原理篇

Oracle提供了大量索引選項。知道在給定條件下使用哪個選項對於一個應用程式的效能來說非常重要。一個錯誤的選擇可能會引發死鎖,
並導致資料庫效能急劇下降或程式終止。而如果做出正確的選擇,則可以合理使用資源,使那些已經執行了幾個小時甚至幾天的程式在幾分鐘得以完成,
這樣會使您立刻成為一位英雄。這篇文章就將簡單的討論每個索引選項。主要有以下內容:

[1] 基本的索引概念
    查詢DBA_INDEXES檢視可得到表中所有索引的列表,注意只能通過USER_INDEXES的方法來檢索模式(schema)的索引。訪問USER_IND_COLUMNS檢視可得到
    一個給定表中被索引的特定列。

[2] 組合索引
    當某個索引包含有多個已索引的列時,稱這個索引為組合(concatented)索引。在 Oracle9i引入跳躍式掃描的索引訪問方法之前,查詢只能在有限條
    件下使用該索引。比如:表emp有一個組合索引鍵,該索引包含了empno、ename和deptno。在Oracle9i之前除非在where之句中對第一列(empno)指定一
    個值,否則就不能使用這個索引鍵進行一次範圍掃描。
    特別注意:在Oracle9i之前,只有在使用到索引的前導索引時才可以使用組合索引!

[3] ORACLE ROWID
    通過每個行的ROWID,索引Oracle提供了訪問單行資料的能力。ROWID其實就是直接指向單獨行的線路圖。如果想檢查重複值或是其他對ROWID本身的引用,
    可以在任何表中使用和指定rowid列。   

[4] 限制索引
    限制索引是一些沒有經驗的開發人員經常犯的錯誤之一。在SQL中有很多陷阱會使一些索引無法使用。下面討論一些常見的問題:
   
    4.1 使用不等於操作符(<>、!=)
        下面的查詢即使在cust_rating列有一個索引,查詢語句仍然執行一次全表掃描。
         select cust_Id,cust_name
         from   customers
         where  cust_rating <> 'aa';
         把上面的語句改成如下的查詢語句,這樣,在採用基於規則的優化器而不是基於代價的優化器(更智慧)時,將會使用索引。
         select cust_Id,cust_name
         from   customers
         where  cust_rating < 'aa' or cust_rating > 'aa';
     特別注意:通過把不等於操作符改成OR條件,就可以使用索引,以避免全表掃描。
    
     4.2 使用IS NULL 或IS NOT NULL
         使用IS NULL 或IS NOT NULL同樣會限制索引的使用。因為NULL值並沒有被定義。在SQL語句中使用NULL會有很多的麻煩。因此建議開發人員在建表時,
         把需要索引的列設成NOT NULL。如果被索引的列在某些行中存在NULL值,就不會使用這個索引(除非索引是一個點陣圖索引,關於點陣圖索引在稍後在詳細討論)。

     4.3 使用函式
         如果不使用基於函式的索引,那麼在SQL語句的WHERE子句中對存在索引的列使用函式時,會使優化器忽略掉這些索引。
         下面的查詢不會使用索引(只要它不是基於函式的索引)
          select empno,ename,deptno
          from   emp
          where  trunc(hiredate)='01-MAY-81';
          把上面的語句改成下面的語句,這樣就可以通過索引進行查詢。
          select empno,ename,deptno
          from   emp
          where  hiredate<(to_date('01-MAY-81')+0.9999);

     4.4 比較不匹配的資料型別
         比較不匹配的資料型別也是比較難於發現的效能問題之一。
         注意下面查詢的例子,account_number是一個VARCHAR2型別,在account_number欄位上有索引。下面的語句將執行全表掃描。
         select bank_name,address,city,state,zip
         from   banks
         where  account_number = 990354;
         Oracle可以自動把where子句變成to_number(account_number)=990354,這樣就限制了索引的使用,改成下面的查詢就可以使用索引:
         select bank_name,address,city,state,zip
         from   banks
         where  account_number ='990354';
     特別注意:不匹配的資料型別之間比較會讓Oracle自動限制索引的使用,即便對這個查詢執行Explain Plan也不能讓您明白為什麼做了一             
      次“全表掃描”。

[5] 選擇性
    使用USER_INDEXES檢視,該檢視中顯示了一個distinct_keys列。比較一下唯一鍵的數量和表中的行數,就可以判斷索引的選擇性。選擇性越高,
    索引返回的資料就越少。

[6] 群集因子(Clustering Factor)
    Clustering Factor位於USER_INDEXES檢視中。該列反映了資料相對於已索引的列是否顯得有序。如果Clustering Factor列的值接近於索引中的樹葉塊
    (leaf block)的數目,表中的資料就越有序。如果它的值接近於表中的行數,則表中的資料就不是很有序。
   

[7] 二元高度(Binary height)
    索引的二元高度對把ROWID返回給使用者程式時所要求的I/O量起到關鍵作用。在對一個索引進行分析後,可以通過查詢DBA_INDEXES的B-level列檢視它的二元高度。
    二元高度主要隨著表的大小以及被索引的列中值的範圍的狹窄程度而變化。索引上如果有大量被刪除的行,它的二元高度也會增加。更新索引列也類似於刪除操作,
    因為它增加了已刪除鍵的數目。重建索引可能會降低二元高度。

[8] 快速全域性掃描
    在Oracle7.3後就可以使用快速全域性掃描(Fast Full Scan)這個選項。這個選項允許Oracle執行一個全域性索引掃描操作。快速全域性掃描讀取B-樹索引上所有樹葉塊。
    初始化檔案中的DB_FILE_MULTIBLOCK_READ_COUNT引數可以控制同時被讀取的塊的數目。

[9] 跳躍式掃描
    從Oracle9i開始,索引跳躍式掃描特性可以允許優化器使用組合索引,即便索引的前導列沒有出現在WHERE子句中。索引跳躍式掃描比全索引掃描要快的多。
    下面的程式清單顯示出效能的差別:
    create index skip1 on emp5(job,empno);
    index created.

    select count(*)
    from emp5
    where empno=7900;

    Elapsed:00:00:03.13

    Execution Plan
    0     SELECT STATEMENT Optimizer=CHOOSE(Cost=4 Card=1 Bytes=5)
    1  0    SORT(AGGREGATE)
    2  1      INDEX(FAST FULL SCAN) OF 'SKIP1'(NON-UNIQUE)

    Statistics

    6826 consistent gets
    6819 physical   reads

    select /*+ index(emp5 skip1)*/ count(*)
    from emp5
    where empno=7900;

    Elapsed:00:00:00.56

    Execution Plan
    0     SELECT STATEMENT Optimizer=CHOOSE(Cost=6 Card=1 Bytes=5)
    1  0    SORT(AGGREGATE)
    2  1      INDEX(SKIP SCAN) OF 'SKIP1'(NON-UNIQUE)

    Statistics

    21 consistent gets
    17 physical   reads

[10] 索引的型別
     B-樹索引
     點陣圖索引
     HASH索引
     索引編排表
     反轉鍵索引
     基於函式的索引
     分割槽索引
     本地和全域性索引

==================================================================================================================================================
--MartriWang@gmail.com  11/05/2007--

索引(INDEX)
  
1.索引是建立在表的一列或多個列上的輔助物件,目的是加快訪問表中的資料;
  
  Oracle儲存索引的資料結構是B*樹,點陣圖索引也是如此,只不過是葉子節點不同B*數索引;
  
  索引由根節點、分支節點和葉子節點組成,上級索引塊包含下級索引塊的索引資料,葉節點包含索引資料和確定行實際位置的rowid。
  
  使用索引的目的
  加快查詢速度
  減少I/O操作
  消除磁碟排序
  
  何時使用索引
  查詢返回的記錄數
  排序表<40%
  非排序表 <7%
  表的碎片較多(頻繁增加、刪除)
  
  索引的種類
  非唯一索引(最常用)
  唯一索引
  點陣圖索引
  區域性有字首分割槽索引
  區域性無字首分割槽索引
  全域性有字首分割槽索引
  雜湊分割槽索引
  基於函式的索引
  
2.管理索引的準則
  
  在表中插入資料後建立索引
  
  。在用SQL*Loader或import工具插入或裝載資料後,建立索引比較有效;
  
  索引正確的表和列
  
  。經常檢索排序大表中40%或非排序表7%的行,建議建索引;
  。為了改善多表關聯,索引列用於聯結;
  。列中的值相對比較唯一;
  。取值範圍(大:B*樹索引,小:點陣圖索引);
  。Date型列一般適合基於函式的索引;
  。列中有許多空值,不適合建立索引
  
  為效能而安排索引列
  
  。經常一起使用多個欄位檢索記錄,組合索引比單索引更有效;
  。把最常用的列放在最前面,例:dx_groupid_serv_id(groupid,serv_id),在where條件中使用groupid或groupid,serv_id,查詢將使用索引,若僅用到serv_id欄位,則索引無效;
  。合併/拆分不必要的索引。
  
  限制每個表索引的數量
  
  。一個表可以有幾百個索引(你會這樣做嗎?),但是對於頻繁插入和更新表,索引越多系統CPU,I/O負擔就越重;
  。建議每張表不超過5個索引。
  
  刪除不再需要的索引
  
  。索引無效,集中表現在該使用基於函式的索引或點陣圖索引,而使用了B*樹索引;
  。應用中的查詢不使用索引;
  。重建索引之前必須先刪除索引,若用alter index … rebuild重建索引,則不必刪除索引。
  
  索引資料塊空間使用
  
  。建立索引時指定表空間,特別是在建立主鍵時,應明確指定表空間;
  。合理設定pctfress,注意:不能給索引指定pctused;
  。估計索引的大小和合理地設定儲存引數,預設為表空間大小,或initial與next設定成一樣大。
  
  考慮並行建立索引
  
  。對大表可以採用並行建立索引,在並行建立索引時,儲存引數被每個查詢伺服器程式分別使用,例如:initial為1M,並行度為8,則建立索引期間至少要消耗8M空間;
  
  考慮用nologging建立索引
  
  。對大表建立索引可以使用nologging來減少重做日誌;
  。節省重做日誌檔案的空間;
  。縮短建立索引的時間;
  。改善了並行建立大索引時的效能。
  
3.怎樣建立最佳索引
  
  明確地建立索引
  create index index_name on table_name(field_name)
  tablespace tablespace_name
  pctfree 5
  initrans 2
  maxtrans 255
  storage
  (
  minextents 1
  maxextents 16382
  pctincrease 0
  );
  
  建立基於函式的索引
  
  。常用與UPPER、LOWER、TO_CHAR(date)等函式分類上,例:
  create index idx_func on emp (UPPER(ename)) tablespace tablespace_name;
  
  建立點陣圖索引
  
  。對基數較小,且基數相對穩定的列建立索引時,首先應該考慮點陣圖索引,例:
  create bitmap index idx_bitm on class (classno) tablespace tablespace_name;
  
  明確地建立唯一索引
  
  。可以用create unique index語句來建立唯一索引,例:
  create unique index dept_unique_idx on dept(dept_no) tablespace idx_1;
  
  建立與約束相關的索引
  
  。可以用using index字句,為與unique和primary key約束相關的索引,例如:
  alter table table_name
  add constraint PK_primary_keyname primary key (field_name)
  using index tablespace tablespace_name;
  
  如何建立區域性分割槽索引
  
  。基礎表必須是分割槽表;
  。分割槽數量與基礎表相同;
  。每個索引分割槽的子分割槽數量與相應的基礎表分割槽相同;
  。基礎表的子分割槽中的行的索引項,被儲存在該索引的相應的子分割槽中,例如:
  Create Index TG_CDR04_SERV_ID_IDX On TG_CDR04(SERV_ID)
  Pctfree 5
  Tablespace TBS_AK01_IDX
  Storage (
  MaxExtents 32768
  PctIncrease 0
  FreeLists 1
  FreeList Groups 1
  )
  local
  /
  
  如何建立範圍分割槽的全域性索引
  
  。基礎表可以是全域性表和分割槽表。
  create index idx_start_date on tg_cdr01(start_date)
  global partition by range(start_date)
  (partition p01_idx vlaues less than (‘0106’)
  partition p01_idx vlaues less than (‘0111’)
  …
  partition p01_idx vlaues less than (‘0401’ ))
  /
  
  重建現存的索引
  
  重建現存的索引的當前時刻不會影響查詢;
  
  重建索引可以刪除額外的資料塊;
  
  提高索引查詢效率;
  alter index idx_name rebuild nologging;
  
  對於分割槽索引:
  alter index idx_name rebuild partition partiton_name nologging;
  
  要刪除索引的原因
  
  。不再需要的索引;
  。索引沒有針對其相關的表所釋出的查詢提供所期望的效能改善;
  。應用沒有用該索引來查詢資料;
  。該索引無效,必須在重建之前刪除該索引;
  。該索引已經變的太碎了,必須在重建之前刪除該索引;
  。語句:
 drop index idx_name;
 drop index idx_name drop partition partition_name;
  
  建立索引的代價
  
  基礎表維護時,系統要同時維護索引,不合理的索引將嚴重影響系統資源,主要表現在CPU和I/O上;
  
  插入、更新、刪除資料產生大量db file sequential read鎖等待;
  
4.SQL優化器簡介
  
  基於規則的優化器
  
  。總是使用索引
  。總是從驅動表開始(from子句最右邊的表)
  。只有在不可避免的情況下,才使用全表掃描
  。任何索引都可以
  
  基於成本的優化器
  
  。需要表、索引的統計資料
  Analyze table customer compute statistics;
  Analyze table customer estimate statistics sample 5000 rows;
  。表中設定並行度、表分割槽

--MartriWang@gmail.com 21/06/2007--
軟體環境:
1. Windows 2000+ORACLE 8.1.7
2. ORACLE安裝路徑為:C:/ORACLE
實現方法:
1. 開始->設定->控制皮膚->管理工具->服務 停止所有Oracle服務。
2. 開始->程式->Oracle - OraHome81->Oracle Installation Products-> Universal Installer 卸裝所有Oracle產品,
但Universal Installer本身不能被刪除
5. 執行regedit,選擇HKEY_LOCAL_MACHINE/SOFTWARE/ORACLE,按del鍵刪除這個入口。
6. 執行regedit,選擇HKEY_LOCAL_MACHINE/SYSTEM/CurrentControlSet/Services,滾動 這個列表,刪除所有Oracle入口。
7. 執行refedit,選擇HKEY_LOCAL_MACHINE/SYSTEM/CurrentControlSet/Services/Eventlog/Application, 刪除所有Oracle入口。
8. 開始->設定->控制皮膚->系統->高階->環境變數 刪除環境變數CLASSPATH和PATH中有關Oracle的設定
9. 從桌面上、STARTUP(啟動)組、程式選單中,刪除所有有關Oracle的組和圖示
10.刪除/Program Files/Oracle目錄
11. 重新啟動計算機,重起後才能完全刪除Oracle所在目錄
12、刪除與Oracle有關的檔案,選擇Oracle所在的預設目錄C:/Oracle,刪除這個入口目錄及所有子目錄,並從Windows 2000目錄
(一般為C:/WINNT)下刪除以下檔案ORACLE.INI、oradim73.INI、oradim80.INI、oraodbc.ini等等。
13. WIN.INI檔案中若有[ORACLE]的標記段,刪除該段
14. 如有必要,刪除所有Oracle相關的ODBC的DSN
15. 到事件檢視器中,刪除Oracle相關的日誌 說明:如果有個別DLL檔案無法刪除的情況,則不用理會,重新啟動,開始新的安裝,
安裝時,選擇一個新的目錄,則,安裝完畢並重新啟動後,老的目錄及檔案就可以刪除掉了
--MartriWang@gmail.com 25/06/2007--
--建立資料表空間
CREATE TABLESPACE TS1
    LOGGING
    DATAFILE 'C:/ORACLE/ORADATA/ORA9/TS1.ORA' SIZE 1M EXTENT
    MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT  AUTO ;

CREATE TABLESPACE TS2
    LOGGING
    DATAFILE 'C:/ORACLE/ORADATA/ORA9/TS2.ORA' SIZE 1M EXTENT
    MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT  AUTO ;

CREATE TABLESPACE TS3
    LOGGING
    DATAFILE 'C:/ORACLE/ORADATA/ORA9/TS3.ORA' SIZE 1M EXTENT
    MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT  AUTO ;

CREATE TABLESPACE TS4
    LOGGING
    DATAFILE 'C:/ORACLE/ORADATA/ORA9/TS4.ORA' SIZE 1M EXTENT
    MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT  AUTO ;

CREATE TABLESPACE TS5
    LOGGING
    DATAFILE 'C:/ORACLE/ORADATA/ORA9/TS5.ORA' SIZE 1M EXTENT
    MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT  AUTO ;

CREATE TABLESPACE TS6
    LOGGING
    DATAFILE 'C:/ORACLE/ORADATA/ORA9/TS6.ORA' SIZE 1M EXTENT
    MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT  AUTO ;

CREATE TABLESPACE TS7
    LOGGING
    DATAFILE 'C:/ORACLE/ORADATA/ORA9/TS7.ORA' SIZE 1M EXTENT
    MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT  AUTO ;

CREATE TABLESPACE TS8
    LOGGING
    DATAFILE 'C:/ORACLE/ORADATA/ORA9/TS8.ORA' SIZE 1M EXTENT
    MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT  AUTO ;

CREATE TABLESPACE TS9
    LOGGING
    DATAFILE 'C:/ORACLE/ORADATA/ORA9/TS9.ORA' SIZE 1M EXTENT
    MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT  AUTO ;

CREATE TABLESPACE TS10
    LOGGING
    DATAFILE 'C:/ORACLE/ORADATA/ORA9/TS10.ORA' SIZE 1M EXTENT
    MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT  AUTO ;

CREATE TABLESPACE TS11
    LOGGING
    DATAFILE 'C:/ORACLE/ORADATA/ORA9/TS11.ORA' SIZE 1M EXTENT
    MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT  AUTO ;

CREATE TABLESPACE TS12
    LOGGING
    DATAFILE 'C:/ORACLE/ORADATA/ORA9/TS12.ORA' SIZE 1M EXTENT
    MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT  AUTO ;
   
--建立索引表空間
CREATE TABLESPACE TSI1
    LOGGING
    DATAFILE 'C:/ORACLE/ORADATA/ORA9/TSI1.ORA' SIZE 1M EXTENT
    MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT  AUTO ;

CREATE TABLESPACE TSI2
    LOGGING
    DATAFILE 'C:/ORACLE/ORADATA/ORA9/TSI2.ORA' SIZE 1M EXTENT
    MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT  AUTO ;

CREATE TABLESPACE TSI3
    LOGGING
    DATAFILE 'C:/ORACLE/ORADATA/ORA9/TSI3.ORA' SIZE 1M EXTENT
    MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT  AUTO ;

CREATE TABLESPACE TSI4
    LOGGING
    DATAFILE 'C:/ORACLE/ORADATA/ORA9/TSI4.ORA' SIZE 1M EXTENT
    MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT  AUTO ;

CREATE TABLESPACE TSI5
    LOGGING
    DATAFILE 'C:/ORACLE/ORADATA/ORA9/TSI5.ORA' SIZE 1M EXTENT
    MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT  AUTO ;

CREATE TABLESPACE TSI6
    LOGGING
    DATAFILE 'C:/ORACLE/ORADATA/ORA9/TSI6.ORA' SIZE 1M EXTENT
    MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT  AUTO ;

CREATE TABLESPACE TSI7
    LOGGING
    DATAFILE 'C:/ORACLE/ORADATA/ORA9/TSI7.ORA' SIZE 1M EXTENT
    MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT  AUTO ;

CREATE TABLESPACE TSI8
    LOGGING
    DATAFILE 'C:/ORACLE/ORADATA/ORA9/TSI8.ORA' SIZE 1M EXTENT
    MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT  AUTO ;

CREATE TABLESPACE TSI9
    LOGGING
    DATAFILE 'C:/ORACLE/ORADATA/ORA9/TSI9.ORA' SIZE 1M EXTENT
    MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT  AUTO ;

CREATE TABLESPACE TSI10
    LOGGING
    DATAFILE 'C:/ORACLE/ORADATA/ORA9/TSI10.ORA' SIZE 1M EXTENT
    MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT  AUTO ;

CREATE TABLESPACE TSI11
    LOGGING
    DATAFILE 'C:/ORACLE/ORADATA/ORA9/TSI11.ORA' SIZE 1M EXTENT
    MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT  AUTO ;

CREATE TABLESPACE TSI12
    LOGGING
    DATAFILE 'C:/ORACLE/ORADATA/ORA9/TSI12.ORA' SIZE 1M EXTENT
    MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT  AUTO ;
   
--範圍分割槽表
drop table sales1;

--範圍必須越來越大
CREATE TABLE sales1(
year int ,
month int,
day int,
fee number)
PARTITION by range (year,month,day)
(
partition sale1 values less than(1999,02,01) tablespace ts1,
partition sale2 values less than(2000,01,01) tablespace ts2,
partition sale3 values less than(2001,01,01) tablespace ts3,
partition sale4 values less than(2002,01,01) tablespace ts4,
partition sale5 values less than(MAXVALUE,MAXVALUE,MAXVALUE) tablespace ts5
);

--第一種索引
drop index idx_sales1;
create index idx_sales1 on sales1(year);

 


--第二種索引
drop index idx_sales1;

--ORA-14021: 必須指定所有列的 MAXVALUE
--ORA-14010: 不可以指定索引分割槽的此物理屬性
create index idx_sales1 on sales1(year)
global partition by range(year)
(
partition sale1 values less than(1999) tablespace tsi1,
partition sale2 values less than(2000) tablespace tsi2,
partition sale3 values less than(2001) tablespace tsi3,
partition sale4 values less than(2002) tablespace tsi4,
partition sale5 values less than(MAXVALUE) tablespace tsi5
);

 

--第三種索引
drop index idx_sales1;
--ORA-14024: LOCAL 索引的分割槽數必須等於基本表的分割槽數(索引分割槽名可以與表分割槽名不一致,不過索引資料怎麼儲存呢?)
CREATE INDEX idx_sales1 ON SALES1  (YEAR)
TABLESPACE EXAMPLE LOCAL
(
PARTITION aSALE1 tablespace tsi1,
PARTITION aSALE2 tablespace tsi2,
PARTITION aSALE3 tablespace tsi3,
PARTITION aSALE4 tablespace tsi4)
;

 

insert into sales1 values(1999,01,01,1);
--null 插入到maxvalue表空間。
insert into sales1 values(null,null,null,0);

--ORA-14400: 插入的分割槽關鍵字未對映到任何分割槽
insert into sales1 values(2004,01,01,1);


commit;

--列表分割槽表
drop table sales2;


--範圍必須越來越大
CREATE TABLE sales2(
year int ,
month int,
day int,
fee number)
PARTITION by list (year)
(
partition sale1 values (1999) tablespace ts1,
partition sale2 values (2000) tablespace ts2,
partition sale3 values (2001) tablespace ts3,
partition sale4 values (2002) tablespace ts4,
partition sale5 values (null) tablespace ts5,
partition sale6 values (default) tablespace ts6
);

--第一種索引
drop index idx_sales2;
create index idx_sales2 on sales2(year);

 


--第二種索引
drop index idx_sales2;

--ORA-14021: 必須指定所有列的 MAXVALUE
--ORA-14010: 不可以指定索引分割槽的此物理屬性
create index idx_sales2 on sales2(year)
global partition by range(year)
(
partition sale1 values less than(1999) tablespace tsi1,
partition sale2 values less than(2000) tablespace tsi2,
partition sale3 values less than(2001) tablespace tsi3,
partition sale4 values less than(2002) tablespace tsi4,
partition sale5 values less than(MAXVALUE) tablespace tsi5
);

 

--第三種索引
drop index idx_sales2;
--ORA-14024: LOCAL 索引的分割槽數必須等於基本表的分割槽數(索引分割槽名可以與表分割槽名不一致,不過索引資料怎麼儲存呢?)

CREATE INDEX idx_sales2 ON sales2  (YEAR)
TABLESPACE EXAMPLE LOCAL
(
PARTITION iSALE1 tablespace tsi1,
PARTITION iSALE2 tablespace tsi2,
PARTITION iSALE3 tablespace tsi3,
PARTITION iSALE4 tablespace tsi4,
PARTITION iSALE5 tablespace tsi5)
;

 

insert into sales2 values(1999,01,01,1);


--ORA-14400: 插入的分割槽關鍵字未對映到任何分割槽
insert into sales2 values(2004,01,01,1);

insert into sales2 values(null,01,01,1);


commit;

/******************************************************************************/
--1 AAAHmyAALAAAAAXAAA 1999 1 1 1 11 11
--2 AAAHm2AAPAAAAAPAAA  1 1 1 15 15
--3 AAAHm3AAQAAAAAPAAA 2004 1 1 1 16 16
/******************************************************************************/

--雜湊分割槽表

drop table sales3;

CREATE TABLE sales3(
year int ,
month int,
day int,
fee number)
PARTITION by hash (year)
partitions 5;


drop table sales3;
--ORA-14170: 不能在 CREATE TABLE|INDEX 中指定 <分割槽 - 說明> 子句
CREATE TABLE sales3(
year int ,
month int,
day int,
fee number)
PARTITION by hash (year)
--partitions 5
(
partition p1 tablespace ts1,
partition p2 tablespace ts2,
partition p3 tablespace ts3,
partition p4 tablespace ts4,
partition p5 tablespace ts5
);

--第一種索引
drop index idx_sales3;
create index idx_sales3 on sales3(year);

 


--第二種索引
drop index idx_sales3;

--ORA-14021: 必須指定所有列的 MAXVALUE
--ORA-14010: 不可以指定索引分割槽的此物理屬性
create index idx_sales3 on sales3(year)
global partition by range(year)
(
partition sale1 values less than(1999) tablespace tsi1,
partition sale2 values less than(2000) tablespace tsi2,
partition sale3 values less than(2001) tablespace tsi3,
partition sale4 values less than(2002) tablespace tsi4,
partition sale5 values less than(MAXVALUE) tablespace tsi5
);

 

--第三種索引
--ORA-14024: LOCAL 索引的分割槽數必須等於基本表的分割槽數(索引分割槽名可以與表分割槽名不一致,不過索引資料怎麼儲存呢?)
drop index idx_sales3;

CREATE INDEX idx_sales3 ON sales3  (YEAR)
TABLESPACE EXAMPLE LOCAL
(
PARTITION SALE1 tablespace tsi1,
PARTITION SALE2 tablespace tsi2,
PARTITION SALE3 tablespace tsi3,
PARTITION SALE4 tablespace tsi4,
PARTITION SALE5 tablespace tsi5)
;

 

insert into sales3 values(1999,01,01,1);


--ORA-14400: 插入的分割槽關鍵字未對映到任何分割槽
insert into sales3 values(2004,01,01,1);

insert into sales3 values(null,01,01,1);


commit;


/******************************************************************************/
--1 AAAHmyAALAAAAAXAAA 1999 1 1 1 11 11
--2 AAAHm2AAPAAAAAPAAA  1 1 1 15 15
--3 AAAHm3AAQAAAAAPAAA 2004 1 1 1 16 16
/******************************************************************************/

--組合分割槽表

drop table sales4;


--組合必須越來越大
CREATE TABLE sales4(
year int ,
month int,
day int,
fee number)
PARTITION by range (year) subpartition by hash(month)
subpartitions 8 store in (ts11,ts12)
(
partition sale1 values less than(1999) tablespace ts1,
partition sale2 values less than(2000) tablespace ts2,
partition sale3 values less than(2001) tablespace ts3,
partition sale4 values less than(2002) tablespace ts4
);


--第一種索引
drop index idx_sales4;
create index idx_sales4 on sales4(year);

 


--第二種索引
drop index idx_sales4;

--ORA-14021: 必須指定所有列的 MAXVALUE
--ORA-14010: 不可以指定索引分割槽的此物理屬性
create index idx_sales4 on sales4(year)
global partition by range(year)
(
partition sale1 values less than(1999) tablespace tsi1,
partition sale2 values less than(2000) tablespace tsi2,
partition sale3 values less than(2001) tablespace tsi3,
partition sale4 values less than(2002) tablespace tsi4,
partition sale5 values less than(MAXVALUE) tablespace tsi5
);

 

--第三種索引
drop index idx_sales4;
--ORA-14024: LOCAL 索引的分割槽數必須等於基本表的分割槽數(索引分割槽名可以與表分割槽名不一致,不過索引資料怎麼儲存呢?)
CREATE INDEX idx_sales4 ON sales4  (YEAR)
TABLESPACE EXAMPLE LOCAL
(
PARTITION aSALE1 tablespace tsi1,
PARTITION aSALE2 tablespace tsi2,
PARTITION aSALE3 tablespace tsi3,
PARTITION aSALE4 tablespace tsi4)
;

 

insert into sales4 values(1999,01,01,1);


--ORA-14400: 插入的分割槽關鍵字未對映到任何分割槽
insert into sales4 values(2004,01,01,1);


commit;

 

 

 

相關文章