<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    JAVA—咖啡館

    ——歡迎訪問rogerfan的博客,常來《JAVA——咖啡館》坐坐,喝杯濃香的咖啡,彼此探討一下JAVA技術,交流工作經驗,分享JAVA帶來的快樂!本網站部分轉載文章,如果有版權問題請與我聯系。

    BlogJava 首頁 新隨筆 聯系 聚合 管理
      447 Posts :: 145 Stories :: 368 Comments :: 0 Trackbacks

    匯總:
    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></filename> password= <password></password> entries=<max_users></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=""></specific>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></eof1> connect internal as sysdba
    shutdown immediate;
    exit
    EOF1
    insert backup commands like the "tar" commands here
    svrmgrl <<eof2></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></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></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></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></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></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></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@> remote_username/remote_password@service_name
    to
    username/password@service_name
    [append|create|insert|replace]
    TABLE_NAME
    using subquery;

    // 在(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

    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></version_name>TNSListener
    net stop Oracle<version_name></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

    posted on 2010-03-24 14:51 rogerfan 閱讀(608) 評論(0)  編輯  收藏 所屬分類: 【數據庫】
    主站蜘蛛池模板: 亚洲国产精品人人做人人爱| 在线观看片免费人成视频播放| 四虎永久免费地址在线观看| 中文成人久久久久影院免费观看 | 国产精品免费看香蕉| a级毛片无码免费真人久久| 大片免费观看92在线视频线视频| 久久精品国产亚洲av四虎| 毛片大全免费观看| 最新国产乱人伦偷精品免费网站 | 亚洲美女视频一区| mm1313亚洲精品无码又大又粗| 免费能直接在线观看黄的视频 | 亚洲日韩精品无码专区| 亚洲国产精品无码久久久秋霞2 | 色猫咪免费人成网站在线观看| 精品在线视频免费| 亚洲国产av一区二区三区丶| 国产成人亚洲影院在线观看| 久久不见久久见免费影院| 毛片a级毛片免费播放100| 99久久久国产精品免费蜜臀| 一级黄色免费大片| 亚洲高清一区二区三区电影| 亚洲国产精品久久网午夜| 亚洲国产精品久久久久网站| 久久久久亚洲AV成人网| 免费看男女下面日出水视频| 国产精品亚洲玖玖玖在线观看| 国产亚洲真人做受在线观看| 亚洲区日韩区无码区| 婷婷综合缴情亚洲狠狠尤物| 亚洲人成精品久久久久| 亚洲伦乱亚洲h视频| 久久精品国产精品亚洲艾| 亚洲啪啪免费视频| 美女被免费网站视频在线| 美女黄频视频大全免费的| a级日本高清免费看| 免费看污成人午夜网站| 四虎永久在线观看免费网站网址|