詳細介紹ORACLE sqlplus指令
一、ORACLE的啟動和關閉
1、在單機環境下要想啟動或關閉ORACLE系統必須首先切換到ORACLE使用者,如下
su - oracle
a、啟動ORACLE系統
oracle>svrmgrl
SVRMGR>connect internal
SVRMGR>startup
SVRMGR>quit
b、關閉ORACLE系統
SVRMGR>shutdown
啟動oracle9i資料庫指令:
$ sqlplus /nolog
SQL*Plus: Release 9.2.0.1.0 - Production on Fri Oct 31 13:53:53 2003
Copyright (c) 1982, 2002, Oracle Corporation. All rights reserved.
SQL> connect / as sysdba
Connected to an idle instance.
SQL> startup^C
SQL> startup
ORACLE instance started.
2、在雙機環境下要想啟動或關閉ORACLE系統必須首先切換到root使用者,如下
su - root
hareg -y oracle
hareg -n oracle
Oracle資料庫有哪幾種啟動方式
說明:
有以下幾種啟動方式:
1、startup nomount
非安裝啟動,這種方式啟動下可執行:重建控制檔案、重建資料庫
讀取init.ora檔案,啟動instance,即啟動SGA和背景程序,這種啟動隻需要init.ora檔案。
2、startup mount dbname
安裝啟動,這種方式啟動下可執行:
資料庫日志歸檔、
資料庫媒體恢複、
使資料檔案聯機或脫機,
重新定位資料檔案、重做日志檔案。
執行“nomount”,然後打開控制檔案,确認資料檔案和聯機日志檔案的位置,
但此時不對資料檔案和日志檔案進行校驗檢查。
3、startup open dbname
先執行“nomount”,然後執行“mount”,再打開包括Redo log檔案在内的所有資料庫檔案,
這種方式下可通路資料庫中的資料。
4、startup,等于以下三個指令
startup nomount
alter database mount
alter database open
5、startup restrict
限制方式啟動
這種方式能夠啟動資料庫,但隻允許具有一定特權的使用者通路
非特權使用者通路時,會出現以下提示:
ERROR:
ORA-01035: ORACLE 隻允許具有 RESTRICTED SESSION 權限的使用者使用
6、startup force
強制啟動方式 bitsCN.com中國網管聯盟
當不能關閉資料庫時,可以用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');
檢視索引的大小
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
play.bitsCN.com累了嗎玩一下吧
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';
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/舊/新
重新确認是否已正确
使用INPUT指令可以在SQL緩沖區中增加一行或多行
SQL>i
SQL>輸入内容
e、調用外部系統編輯器
SQL>edit 檔案名
可以使用DEFINE指令設定系統變量EDITOR來改變文本編輯器的類型,在login.sql檔案中定義如下一行
DEFINE_EDITOR=vi
f、運作指令檔案
SQL>START test
SQL>@test
常用SQL*Plus語句
a、表的建立、修改、删除
建立表的指令格式如下:
create table 表名 (列說明清單);
為基表增加新列指令如下:
ALTER TABLE 表名 ADD (列說明清單)
例:為test表增加一列Age,用來存放年齡
sql>alter table test
add (Age number(3));
修改基表列定義指令如下:
ALTER TABLE 表名
MODIFY (列名 資料類型)
例:将test表中的Count列寬度加長為10個字元
sql>alter atble test
modify (County char(10));
b、将一張表删除語句的格式如下:
DORP TABLE 表名;
例:表删除将同時删除表的資料和表的定義
sql>drop table test
c、表空間的建立、删除
六、ORACLE邏輯備份的SH檔案
完全備份的SH檔案:exp_comp.sh
rq=` date +"%m%d" `
su - oracle -c "exp system/manager full=y inctype=complete
file=/oracle/export/db_comp$rq.dmp"
累計備份的SH檔案:exp_cumu.sh
su - oracle -c "exp system/manager full=y inctype=cumulative
file=/oracle/export/db_cumu$rq.dmp"
增量備份的SH檔案: exp_incr.sh
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
..…
RETURN NULL
LPAD(char1,n,char2)函數
字元char1按制定的位數n顯示,不足的位數用char2字元串替換左邊的空位
字段名之間可以進行算術運算
例如: (字段名1*字段名1)/3
查詢語句可以嵌套
例如: SELECT …… FROM
(SELECT …… FROM表名1, [表名2, ……] WHERE 條件) WHERE 條件2;
bitsCN_com關注網管是我們的使命
兩個查詢語句的結果可以做集合操作
例如: 并集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 ……] ;
表名1.字段名 = 表名2. 字段名(+) [ AND ……] ;
有(+)号的字段位置自動補空值
查詢結果集的排序操作, 預設的排序是升序ASC, 降序是DESC
SELECT字段名1, 字段名2, …… FROM 表名1, [表名2, ……]
ORDER BY字段名1, 字段名2 DESC;
字元串模糊比較的方法
INSTR(字段名, ‘字元串’)>0
字段名 LIKE ‘字元串%’ [‘%字元串%’]
每個表都有一個隐含的字段ROWID, 它标記着記錄的唯一性.
四.ORACLE裡常用的資料對象 (SCHEMA)
1.索引 (INDEX)
CREATE INDEX 索引名ON 表名 ( 字段1, [字段2, ……] );
ALTER INDEX 索引名 REBUILD;
一個表的索引最好不要超過三個 (特殊的大表除外), 最好用單字段索引, 結合SQL語句的分析執行情況,
也可以建立多字段的組合索引和基于函數的索引
ORACLE8.1.7字元串可以索引的最大長度為1578 單位元組
ORACLE8.0.6字元串可以索引的最大長度為758 單位元組
2.視圖 (VIEW)
CREATE VIEW 視圖名AS SELECT …. FROM …..;
ALTER VIEW視圖名 COMPILE;
視圖僅是一個SQL查詢語句, 它可以把表之間複雜的關系簡潔化.
3.同義詞 (SYNONMY)
CREATE SYNONYM同義詞名FOR 表名;
CREATE SYNONYM同義詞名FOR 表名@資料庫連結名;
4.資料庫連結 (DATABASE LINK)
CREATE DATABASE LINK資料庫連結名CONNECT TO 使用者名 IDENTIFIED BY 密碼 USING
‘資料庫連接配接字元串’;
資料庫連接配接字元串可以用NET8 EASY CONFIG或者直接修改TNSNAMES.ORA裡定義.
資料庫參數global_name=true時要求資料庫連結名稱跟遠端資料庫名稱一樣
資料庫全局名稱可以用以下指令查出
SELECT * FROM GLOBAL_NAME;
查詢遠端資料庫裡的表
五.權限管理 (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;
查詢資料庫中各種錯誤代碼的總和:
bitsCN_com
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
本文轉自vcdog 51CTO部落格,原文連結:http://blog.51cto.com/255361/837686,如需轉載請自行聯系原作者