免费视频淫片aa毛片_日韩高清在线亚洲专区vr_日韩大片免费观看视频播放_亚洲欧美国产精品完整版

打開APP
userphoto
未登錄

開通VIP,暢享免費電子書等14項超值服

開通VIP
Oracle常用命令筆記

一、ORACLE的啟動和關(guān)閉
1、在單機環(huán)境下
要想啟動或關(guān)閉ORACLE系統(tǒng)必須首先切換到ORACLE用戶,如下
su - oracle

Oracle數(shù)據(jù)庫有哪幾種啟動方式

有以下幾種啟動方式:
1、startup nomount
非安裝啟動,這種方式啟動下可執(zhí)行:重建控制文件、重建數(shù)據(jù)庫
讀取init.ora文件,啟動instance,即啟動SGA和后臺進程,這種啟動只需要init.ora文件。

2、startup mount dbname
安裝啟動,這種方式啟動下可執(zhí)行:
數(shù)據(jù)庫日志歸檔、
數(shù)據(jù)庫介質(zhì)恢復(fù)、
使數(shù)據(jù)文件聯(lián)機或脫機,
重新定位數(shù)據(jù)文件、重做日志文件。

執(zhí)行“nomount”,然后打開控制文件,確認數(shù)據(jù)文件和聯(lián)機日志文件的位置,
但此時不對數(shù)據(jù)文件和日志文件進行校驗檢查。

3、startup open dbname
先執(zhí)行“nomount”,然后執(zhí)行“mount”,再打開包括Redo log文件在內(nèi)的所有數(shù)據(jù)庫文件,
這種方式下可訪問數(shù)據(jù)庫中的數(shù)據(jù)。

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

5、startup restrict
約束方式啟動
這種方式能夠啟動數(shù)據(jù)庫,但只允許具有一定特權(quán)的用戶訪問
非特權(quán)用戶訪問時,會出現(xiàn)以下提示:
ERROR:
ORA-01035: ORACLE 只允許具有 RESTRICTED SESSION 權(quán)限的用戶使用

6、startup force
強制啟動方式
當(dāng)不能關(guān)閉數(shù)據(jù)庫時,可以用startup force來完成數(shù)據(jù)庫的關(guān)閉
先關(guān)閉數(shù)據(jù)庫,再執(zhí)行正常啟動數(shù)據(jù)庫命令

7、startup pfile=參數(shù)文件名
帶初始化參數(shù)文件的啟動方式
先讀取參數(shù)文件,再按參數(shù)文件中的設(shè)置啟動數(shù)據(jù)庫
例:startup pfile=E:Oracleadminoradbpfileinit.ora

b、關(guān)閉ORACLE系統(tǒng)
SQL>shutdown normal
SQL
>shutdown transactional
SQL
>shutdown immediate
SQL
>shutdown abort

oracle數(shù)據(jù)庫幾種關(guān)閉方式:

1、shutdown normal
  正常方式關(guān)閉數(shù)據(jù)庫。
2、shutdown immediate
  立即方式關(guān)閉數(shù)據(jù)庫。
  在SVRMGRL中執(zhí)行shutdown immediate,數(shù)據(jù)庫并不立即關(guān)閉,
  而是在Oracle執(zhí)行某些清除工作后才關(guān)閉(終止會話、釋放會話資源),
  當(dāng)使用shutdown不能關(guān)閉數(shù)據(jù)庫時,shutdown immediate可以完成數(shù)據(jù)庫關(guān)閉的操作。
3、shutdown abort
  直接關(guān)閉數(shù)據(jù)庫,正在訪問數(shù)據(jù)庫的會話會被突然終止,
  如果數(shù)據(jù)庫中有大量操作正在執(zhí)行,這時執(zhí)行shutdown abort后,重新啟動數(shù)據(jù)庫需要很長時間。


二、用戶如何有效地利用數(shù)據(jù)字典
   ORACLE的數(shù)據(jù)字典是數(shù)據(jù)庫的重要組成部分之一,它隨著數(shù)據(jù)庫的產(chǎn)生而產(chǎn)生, 隨著數(shù)據(jù)庫的變化而變化,
體現(xiàn)為sys用戶下的一些表和視圖。數(shù)據(jù)字典名稱是大寫的英文字符。

    數(shù)據(jù)字典里存有用戶信息、用戶的權(quán)限信息、所有數(shù)據(jù)對象信息、表的約束條件、統(tǒng)計分析數(shù)據(jù)庫的視圖等。
我們不能手工修改數(shù)據(jù)字典里的信息。

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

  dictionary   全部數(shù)據(jù)字典表的名稱和解釋,它有一個同義詞dict
    dict_column   全部數(shù)據(jù)字典表里字段名稱和解釋

    如果我們想查詢跟索引有關(guān)的數(shù)據(jù)字典時,可以用下面這條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';

    依此類推,就可以輕松知道數(shù)據(jù)字典的詳細名稱和解釋,不用查看ORACLE的其它文檔資料了。

    下面按類別列出一些ORACLE用戶常用數(shù)據(jù)字典的查詢使用方法。

    1、用戶
            查看當(dāng)前用戶的缺省表空間
            SQL>select username,default_tablespace from user_users;

        查看當(dāng)前用戶的角色
        SQL>select * from user_role_privs;

        查看當(dāng)前用戶的系統(tǒng)權(quán)限和表級權(quán)限
        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;

            查看某表的創(chuàng)建時間
            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的內(nèi)存區(qū)里的表
            SQL>select table_name,cache from user_tables where instr(cache,'Y')>0;

    3、索引
            查看索引個數(shù)和類別
            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是當(dāng)前值
            SQL>select * from user_sequences;

    5、視圖
            查看視圖的名稱
            SQL>select view_name from user_views;

            查看創(chuàng)建視圖的select語句
            SQL>set view_name,text_length from user_views;
            SQL>set long 2000;                說明:可以根據(jù)視圖的text_length值設(shè)定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、存儲函數(shù)和過程
            查看函數(shù)和過程的狀態(tài)
            SQL>select object_name,status from user_objects where object_type='FUNCTION';
            SQL>select object_name,status from user_objects where object_type='PROCEDURE';

            查看函數(shù)和過程的源代碼
            SQL>select text from all_source where owner=user and name=upper('&plsql_name');

三、查看數(shù)據(jù)庫的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、查看數(shù)據(jù)庫庫對象
    select owner, object_type, status, count(*) count# from all_objects group by owner, object_type, status;
8、查看數(shù)據(jù)庫的版本
    Select version FROM Product_component_version
    Where SUBSTR(PRODUCT,1,6)='Oracle';
9、查看數(shù)據(jù)庫的創(chuàng)建日期和歸檔方式
    Select Created, Log_Mode, Log_Mode From V$Database;
四、ORACLE用戶連接的管理

用系統(tǒng)管理員,查看當(dāng)前數(shù)據(jù)庫有幾個用戶連接:
SQL> select username,sid,serial# from v$session;
如果要停某個連接用
SQL> alter system kill session 'sid,serial#';
如果這命令不行,找它UNIX的進程數(shù)
SQL> select pro.spid from v$session ses,v$process pro where ses.sid=23 and ses.paddr=pro.addr;
說明:23是某個連接的sid數(shù)

然后用 kill 命令殺此進程號。

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

   退出SQL*Plus
SQL>exit

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

c、顯示表結(jié)構(gòu)命令DESCRIBE
SQL>DESC 表名

d、SQL*Plus中的編輯命令
顯示SQL緩沖區(qū)命令
SQL>L

修改SQL命令
首先要將待改正行變?yōu)楫?dāng)前行
SQL>n
用CHANGE命令修改內(nèi)容
SQL>c/舊/新
重新確認是否已正確
SQL>L

使用INPUT命令可以在SQL緩沖區(qū)中增加一行或多行
SQL>i
SQL>輸入內(nèi)容

e、調(diào)用外部系統(tǒng)編輯器
SQL>edit 文件名
可以使用DEFINE命令設(shè)置系統(tǒng)變量EDITOR來改變文本編輯器的類型,在login.sql文件中定義如下一行
DEFINE_EDITOR=vi

f、運行命令文件
SQL>START test
SQL>@test

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

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

修改基表列定義命令如下:
ALTER TABLE 表名
MODIFY (列名 數(shù)據(jù)類型)
例:將test表中的Count列寬度加長為10個字符
    sql>alter atble test
        modify (County char(10));

b、將一張表刪除語句的格式如下:
DORP TABLE 表名;
例:表刪除將同時刪除表的數(shù)據(jù)和表的定義
sql>drop table test

c、表空間的創(chuàng)建、刪除

六、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_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增加以下內(nèi)容
0 2 1 * * /oracle/exp_comp.sh

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

七、ORACLE 常用的SQL語法和數(shù)據(jù)對象
一.數(shù)據(jù)控制語句 (DML) 部分

1.INSERT  (往數(shù)據(jù)表里插入記錄的語句)

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

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

日期字段的字段值可以用當(dāng)前數(shù)據(jù)庫的系統(tǒng)時間SYSDATE, 精確到秒
或者用字符串轉(zhuǎn)換成日期型函數(shù)TO_DATE(‘2001-08-01’,’YYYY-MM-DD’)
TO_DATE()還有很多種日期格式, 可以參看ORACLE DOC.
年-月-日 小時:分鐘:秒 的格式Y(jié)YYY-MM-DD HH24:MI:SS

INSERT時最大可操作的字符串長度小于等于4000個單字節(jié), 如果要插入更長的字符串, 請考慮字段用CLOB類型,
方法借用ORACLE里自帶的DBMS_LOB程序包.

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

2.DELETE  (刪除數(shù)據(jù)表里記錄的語句)

DELETE FROM表名 WHERE 條件;

注意:刪除記錄并不能釋放ORACLE里被占用的數(shù)據(jù)塊表空間. 它只把那些被刪除的數(shù)據(jù)塊標成unused.

如果確實要刪除一個大表里的全部記錄, 可以用 TRUNCATE 命令, 它可以釋放占用的數(shù)據(jù)塊表空間
TRUNCATE TABLE 表名;
此操作不可回退.

3.UPDATE  (修改數(shù)據(jù)表里記錄的語句)

UPDATE表名 SET 字段名1=值1, 字段名2=值2, …… WHERE 條件;

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

注意事項:
A.        以上SQL語句對表都加上了行級鎖,
        確認完成后, 必須加上事物處理結(jié)束的命令 COMMIT 才能正式生效,
        否則改變不一定寫入數(shù)據(jù)庫里.
        如果想撤回這些操作, 可以用命令 ROLLBACK 復(fù)原.

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

1.CREATE (創(chuàng)建表, 索引, 視圖, 同義詞, 過程, 函數(shù), 數(shù)據(jù)庫鏈接等)

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

創(chuàng)建表時要把較小的不為空的字段放在前面, 可能為空的字段放在后面

創(chuàng)建表時可以用中文的字段名, 但最好還是用英文的字段名

創(chuàng)建表時可以給字段加上默認值, 例如 DEFAULT SYSDATE
這樣每次插入和修改時, 不用程序操作這個字段都能得到動作的時間

創(chuàng)建表時可以給字段加上約束條件
例如 不允許重復(fù) UNIQUE, 關(guān)鍵字 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 (字段名);

把表放在或取出數(shù)據(jù)庫的內(nèi)存區(qū)
ALTER TABLE 表名 CACHE;
ALTER TABLE 表名 NOCACHE;

3.DROP        (刪除表, 索引, 視圖, 同義詞, 過程, 函數(shù), 數(shù)據(jù)庫鏈接等)

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

4.TRUNCATE (清空表里的所有記錄, 保留表的結(jié)構(gòu))

TRUNCATE 表名;

三.查詢語句 (SELECT) 部分

SELECT字段名1, 字段名2, …… FROM 表名1, [表名2, ……] WHERE 條件;

字段名可以帶入函數(shù)
  例如:  COUNT(*), MIN(字段名),  MAX(字段名),  AVG(字段名), DISTINCT(字段名),
           TO_CHAR(DATE字段名,'YYYY-MM-DD HH24:MI:SS')

NVL(EXPR1, EXPR2)函數(shù)
解釋:
IF EXPR1=NULL
                RETURN EXPR2
ELSE
                       RETURN EXPR1

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

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

字段名之間可以進行算術(shù)運算
例如:  (字段名1*字段名1)/3

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

兩個查詢語句的結(jié)果可以做集合操作
例如: 并集UNION(去掉重復(fù)記錄), 并集UNION ALL(不去掉重復(fù)記錄), 差集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 ……] ;

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

查詢結(jié)果集的排序操作, 默認的排序是升序ASC, 降序是DESC

SELECT字段名1, 字段名2, …… FROM 表名1, [表名2, ……]
ORDER BY字段名1, 字段名2 DESC;

字符串模糊比較的方法

INSTR(字段名, ‘字符串’)>0
字段名 LIKE  ‘字符串%’  [‘%字符串%’]

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

四.ORACLE里常用的數(shù)據(jù)對象 (SCHEMA)

1.索引 (INDEX)

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

一個表的索引最好不要超過三個 (特殊的大表除外), 最好用單字段索引, 結(jié)合SQL語句的分析執(zhí)行情況,
也可以建立多字段的組合索引和基于函數(shù)的索引

ORACLE8.1.7字符串可以索引的最大長度為1578 單字節(jié)
ORACLE8.0.6字符串可以索引的最大長度為758 單字節(jié)

2.視圖 (VIEW)

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

視圖僅是一個SQL查詢語句, 它可以把表之間復(fù)雜的關(guān)系簡潔化.

3.同義詞 (SYNONMY)
CREATE SYNONYM同義詞名FOR 表名;
CREATE SYNONYM同義詞名FOR 表名@數(shù)據(jù)庫鏈接名;

4.數(shù)據(jù)庫鏈接 (DATABASE LINK)
CREATE DATABASE LINK數(shù)據(jù)庫鏈接名CONNECT TO 用戶名 IDENTIFIED BY 密碼 USING ‘?dāng)?shù)據(jù)庫連接字符串’;

數(shù)據(jù)庫連接字符串可以用NET8 EASY CONFIG或者直接修改TNSNAMES.ORA里定義.

數(shù)據(jù)庫參數(shù)global_name=true時要求數(shù)據(jù)庫鏈接名稱跟遠端數(shù)據(jù)庫名稱一樣

數(shù)據(jù)庫全局名稱可以用以下命令查出
SELECT * FROM GLOBAL_NAME;

查詢遠端數(shù)據(jù)庫里的表
SELECT …… FROM 表名@數(shù)據(jù)庫鏈接名;

五.權(quán)限管理 (DCL) 語句

1.GRANT        賦于權(quán)限
常用的系統(tǒng)權(quán)限集合有以下三個:
CONNECT(基本的連接), RESOURCE(程序開發(fā)), DBA(數(shù)據(jù)庫管理)
常用的數(shù)據(jù)對象權(quán)限有以下五個:
ALL         ON 數(shù)據(jù)對象名,         SELECT ON 數(shù)據(jù)對象名,         UPDATE ON 數(shù)據(jù)對象名,
DELETE         ON 數(shù)據(jù)對象名,  INSERT ON 數(shù)據(jù)對象名,   ALTER  ON 數(shù)據(jù)對象名

GRANT CONNECT, RESOURCE TO 用戶名;
GRANT SELECT ON 表名 TO 用戶名;
GRANT SELECT, INSERT, DELETE ON表名 TO 用戶名1, 用戶名2;

2.REVOKE 回收權(quán)限

REVOKE CONNECT, RESOURCE FROM 用戶名;
REVOKE SELECT ON 表名 FROM 用戶名;
REVOKE SELECT, INSERT, DELETE ON表名 FROM 用戶名1, 用戶名2;

 

八.修改SGA參數(shù)
    修改SGA的原則

        sga_target <= sga_max_size
        SGA加上PGA等其他進程占用的內(nèi)存必須少于機器物理內(nèi)存。

    命令
        SQL>alter system set sga_max_size=2048m scope=spfile;
        SQL>alter system set sga_target=2048m scope=spfile;
        ##修改SGA的相關(guān)參數(shù),只能spfile,然后重啟數(shù)據(jù)庫。不能直接scope=both!

九.查詢Oracle配置參數(shù)
    命令
        SQL>show parameter;
    具體查詢某個Oracle參數(shù),只需輸入部分關(guān)鍵字即可,比如:查詢sga_target的值。
        復(fù)制代碼
        SQL> show parameter sga;

        NAME                                 TYPE        VALUE
        ------------------------------------ ----------- ------------------------------
        lock_sga                             boolean     FALSE
        pre_page_sga                         boolean     FALSE
        sga_max_size                         big integer 2G
        sga_target                           big integer 2G
        SQL>
        復(fù)制代碼

十.管理Oracle Enterprise Manager
    查詢OEM狀態(tài)
        emctl status dbconsole
    啟動OEM
        emctl start dbconsole
    關(guān)閉OEM
        emctl stop dbconsole

十一.redo logfile管理
    日志切換時間間隔查詢
        SELECT to_char(b.first_time, 'YYYY-MM-DD HH24:MI:SS') as swtich_time, (b.first_time - a.first_time) * 24 as "switch_interval(hr)" FROM v$log_history a, v$log_history b WHERE a.SEQUENCE# + 1 = b.SEQUENCE# ORDER BY SWTICH_TIME;
        --------
        ##前一百條記錄(反序)
        SELECT to_char(b.first_time, 'YYYY-MM-DD HH24:MI:SS') as swtich_time, (b.first_time - a.first_time) * 24 as "switch_interval(hr)" FROM v$log_history a, v$log_history b WHERE a.SEQUENCE# + 1 = b.SEQUENCE# AND ROWNUM <= 100 ORDER BY SWTICH_TIME desc;

     查詢當(dāng)前的日志設(shè)置情況
        復(fù)制代碼
        SQL> col MEMBER for a40
        SQL> select * From v$logfile;

            GROUP# STATUS  TYPE                 MEMBER                                   IS_
        ---------- ------- -------------------- ---------------------------------------- ---
                 1         ONLINE               /u01/app/oracle/oradata/ORA10G/redo01.log  NO
                 2         ONLINE               /u01/app/oracle/oradata/ORA10G/redo02.log  NO
                 3         ONLINE               /u01/app/oracle/oradata/ORA10G/redo03.log  NO
        SQL>select * from v$log;

            GROUP#    THREAD#  SEQUENCE#      BYTES    MEMBERS ARC STATUS           FIRST_CHANGE# FIRST_TIM
        ---------- ---------- ---------- ---------- ---------- --- ---------------- ------------- ---------
                 1          1      13690   52428800          1 NO  CURRENT              192645086 10-FEB-09
                 2          1      13689   52428800          1 YES INACTIVE             192633926 10-FEB-09
                 3          1      13688   52428800          1 YES INACTIVE             192614912 10-FEB-09
        復(fù)制代碼

    添加兩個臨時日志組
        SQL> alter database add logfile group 4 ('/u01/app/oracle/oradata/ORA10G/redo04.log') size 200M;
        SQL> alter database add logfile group 5 ('/u01/app/oracle/oradata/ORA10G/redo05.log') size 200M;
    將當(dāng)前的Online Redo Log切換到新增的Redo log group上
        復(fù)制代碼
        SQL> alter system switch logfile;
        SQL> alter system switch logfile;

        //檢查是否已經(jīng)切換到新增的Online Redo log group上:
        SQL> select * from v$log;

            GROUP#    THREAD#  SEQUENCE#      BYTES    MEMBERS ARC STATUS           FIRST_CHANGE# FIRST_TIM
        ---------- ---------- ---------- ---------- ---------- --- ---------------- ------------- ---------
                 1          1      13695   52428800          1 YES INACTIVE             192653667 10-FEB-09
                 2          1      13694   52428800          1 YES INACTIVE             192653616 10-FEB-09
                 3          1      13693   52428800          1 YES INACTIVE             192653593 10-FEB-09
                 4          1      13696  209715200          1 NO  CURRENT              192653673 10-FEB-09
                 5          1      13692  209715200          1 YES INACTIVE             192653549 10-FEB-09
        復(fù)制代碼
    刪除原來的Online Redo Logs
        復(fù)制代碼
        SQL>  alter database drop logfile group 1;
        SQL>  alter database drop logfile group 2;
        SQL>  alter database drop logfile group 3;

        //然后需要手動在對應(yīng)目錄下,手動刪除redo logfile文件。
        SQL> !
        [oracle@orcal-50 ~]$ cd /u01/app/oracle/oradata/ORA10G/
        [oracle@orcal-50 ORA10G]$rm -rf redo01.log
        [oracle@orcal-50 ORA10G]$rm -rf redo02.log
        [oracle@orcal-50 ORA10G]$rm -rf redo03.log
   
十二.歸檔(Archive)控制
    查詢歸檔狀態(tài)
        SQL> archive log list
        Database log mode              No Archive Mode
        Automatic archival             Disabled
        Archive destination            USE_DB_RECOVERY_FILE_DEST
        Oldest online log sequence     940
        Current log sequence           942
    開啟歸檔
        SQL> shutdown immediate
        SQL> startup mount
        SQL> alter database archivelog
        SQL> alter database open
    關(guān)閉歸檔
        SQL> shutdown immediate
        SQL> startup mount
        SQL> alter database noarchivelog
        SQL> alter database open

十三.查詢Oracle數(shù)據(jù)庫管理員
    select username from dba_users;

 

十四.修改表空間

 

1.增加額外的數(shù)據(jù)文件到表空間中
alter tablespace users add datafile '/u01/oradata/orcl/users02.dbf' size 25m;
修改原有的文件到小
alter database datafile '/oracle/oraHome/oradata/xms/xms_INDX01.dbf' resize 2048m;
下面這句是查看表空間文件的總大小,不是實際使用大小。
select name,bytes/1024/1024 from v$datafile;
 
2.修改表空間名稱
在Oracle10g以前,tablespace的name是不可以隨意修改的,只能drop掉之后重建,但是在10g之后,oracle加入了修改的功能,
為TableSpace改名的舉例如下:
  SQL> create tablespace zs_tbs datafile '/opt/oracle/product/10.2.0/oradata/zs/zs_tbs.dbf' size 1M;
  Tablespace created.
SQL> alter tablespace zs_tbs rename to zs_tbs2;
  Tablespace altered.
SQL> select tablespace_name,status from dba_tablespaces;
  TABLESPACE_NAME                                              STATUS
------------------------------------------------------------ -------------
SYSTEM                                                       ONLINE
UNDOTBS1                                                     ONLINE
SYSAUX                                                       ONLINE
TEMP                                                         ONLINE
USERS                                                        ONLINE
OWB_TBS                                                      ONLINE
RECOVERY_TBS                                                 ONLINE
STREAM_TBS                                                   ONLINE
ZS_TBS2                                                      ONLINE

SQL> select tablespace_name,file_name,status from dba_data_files;
  TABLESPACE_N FILE_NAME                                                         STATUS
------------ ------------------------------------------------------------------ -------------
USERS        /opt/oracle/product/10.2.0/oradata/zs/users01.dbf          AVAILABLE
SYSAUX       /opt/oracle/product/10.2.0/oradata/zs/sysaux01.dbf         AVAILABLE
UNDOTBS1     /opt/oracle/product/10.2.0/oradata/zs/undotbs01.dbf        AVAILABLE
SYSTEM       /opt/oracle/product/10.2.0/oradata/zs/system01.dbf         AVAILABLE
OWB_TBS      /opt/oracle/product/10.2.0/oradata/zs/owb_tbs01.dbf        AVAILABLE
RECOVERY_TBS /opt/oracle/product/10.2.0/oradata/zs/recover_tbs.dbf      AVAILABLE
STREAM_TBS   /opt/oracle/product/10.2.0/oradata/zs/stream_tbs01.dbf     AVAILABLE
ZS_TBS2     /opt/oracle/product/10.2.0/oradata/zs/zs_tbs.dbf            AVAILABLE
此時,datafile的名字沒有改過來,與tablespace不一致,所以需要再改一下,這個過程相對來說比較復(fù)雜,要以下面的順序來修改:
 
    1、把相應(yīng)的tablespace改成read only;
    2、把需要修改的datafile置為offline;
    3、在操作系統(tǒng)中改名
    4、alter database rename file .. to ..;
    5、把相應(yīng)的datafile置為online;
    6、把相應(yīng)tablespace改成read write;
     具體操作如下:
  SQL> alter database rename file '/opt/oracle/product/10.2.0/oradata/zs/zs_tbs.dbf' to '/opt/oracle/product/10.2.0/oradata/zs/zs_tbs2.dbf';
alter database rename file '/opt/oracle/product/10.2.0/oradata/zs/zs_tbs.dbf' to '/opt/oracle/product/10.2.0/oradata/zs/zs_tbs2.dbf'
*
ERROR at line 1:
ORA-01511: error in renaming log/data files
ORA-01121: cannot rename database file 11 - file is in use or recovery
ORA-01110: data file 11: '/opt/oracle/product/10.2.0/oradata/zs/zs_tbs.dbf'

  SQL> alter tablespace zs_tbs2 read only;
  Tablespace altered.
  SQL> alter database datafile '/opt/oracle/product/10.2.0/oradata/zs/zs_tbs.dbf' offline;
  Database altered.
  SQL> host mv /opt/oracle/product/10.2.0/oradata/zs/zs_tbs.dbf /opt/oracle/product/10.2.0/oradata/zs/zs_tbs2.dbf;
  SQL> host ls -l /opt/oracle/product/10.2.0/oradata/zs/
total 6115528
-rw-r----- 1 oracle oinstall 1073750016 Jul 28 01:35 owb_tbs01.dbf
-rw-r----- 1 oracle oinstall   26222592 Jul 28 01:35 recover_tbs.dbf
-rw-r----- 1 oracle oinstall  209723392 Jul 28 01:35 stream_tbs01.dbf
-rw-r----- 1 oracle oinstall  471867392 Jul 28 16:05 sysaux01.dbf
-rw-r----- 1 oracle oinstall  566239232 Jul 28 16:08 system01.dbf
-rw-r----- 1 oracle oinstall   31465472 Jul 27 22:00 temp01.dbf
-rw-r----- 1 oracle oinstall  513810432 Jul 28 16:10 undotbs01.dbf
-rw-r----- 1 oracle oinstall    5251072 Jul 28 10:14 users01.dbf
-rw-r----- 1 oracle oinstall    1056768 Jul 28 16:08 zs_tbs2.dbf
  SQL> alter database rename file '/opt/oracle/product/10.2.0/oradata/zs/zs_tbs.dbf' to '/opt/oracle/product/10.2.0/oradata/zs/zs_tbs2.dbf';
  Database altered.
  SQL> alter database datafile '/opt/oracle/product/10.2.0/oradata/zs/zs_tbs2.dbf' online;
  Database altered.
  SQL> alter tablespace zs_tbs2 read write;
  Tablespace altered.
  SQL> select tablespace_name,file_name,status from dba_data_files;
  TABLESPACE_N FILE_NAME                                                         STATUS
------------ ------------------------------------------------------------------ ------------------
USERS        /opt/oracle/product/10.2.0/oradata/zs/users01.dbf          AVAILABLE
SYSAUX       /opt/oracle/product/10.2.0/oradata/zs/sysaux01.dbf         AVAILABLE
UNDOTBS1     /opt/oracle/product/10.2.0/oradata/zs/undotbs01.dbf        AVAILABLE
SYSTEM       /opt/oracle/product/10.2.0/oradata/zs/system01.dbf         AVAILABLE
OWB_TBS      /opt/oracle/product/10.2.0/oradata/zs/owb_tbs01.dbf        AVAILABLE
RECOVERY_TBS /opt/oracle/product/10.2.0/oradata/zs/recover_tbs.dbf      AVAILABLE
STREAM_TBS   /opt/oracle/product/10.2.0/oradata/zs/stream_tbs01.dbf     AVAILABLE
ZS_TBS2      /opt/oracle/product/10.2.0/oradata/zs/zs_tbs2.dbf          AVAILABLE
  8 rows selected.
本站僅提供存儲服務(wù),所有內(nèi)容均由用戶發(fā)布,如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊舉報
打開APP,閱讀全文并永久保存 查看更多類似文章
猜你喜歡
類似文章
Oracle的備份與恢復(fù)詳解
Oracle數(shù)據(jù)庫-建庫、建表空間,建用戶
oracle UNDO表空間不足解決方法
Oracle undo 表空間管理
PLSQL Developer圖形化窗口創(chuàng)建數(shù)據(jù)庫全過程
臨時表空間管理
更多類似文章 >>
生活服務(wù)
分享 收藏 導(dǎo)長圖 關(guān)注 下載文章
綁定賬號成功
后續(xù)可登錄賬號暢享VIP特權(quán)!
如果VIP功能使用有故障,
可點擊這里聯(lián)系客服!

聯(lián)系客服