1、在單機環境下要想啓動或關閉ORACLE系統必須首先切換到ORACLE用戶,如下
su - oracle
oracle>svrmgrl
SVRMGR>connect internal
SVRMGR>startup
SVRMGR>quit
oracle>svrmgrl
SVRMGR>connect internal
SVRMGR>shutdown
SVRMGR>quit
$ 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.
Connected to an idle instance.
SQL> startup^C
ORACLE instance started.
su - root
hareg -y oracle
hareg -n oracle
1、startup nomount
非安裝啓動,這種方式啓動下可執行:重建控制文件、重建數據庫
讀取init.ora文件,啓動instance,即啓動SGA和後臺進程,這種啓動只需要init.ora文件。
安裝啓動,這種方式啓動下可執行:
數據庫日誌歸檔、
數據庫介質恢復、
使數據文件聯機或脫機,
重新定位數據文件、重做日誌文件。
但此時不對數據文件和日誌文件進行校驗檢查。
先執行“nomount”,然後執行“mount”,再打開包括Redo log文件在內的所有數據庫文件,
這種方式下可訪問數據庫中的數據。
startup nomount
alter database mount
alter database open
約束方式啓動
這種方式能夠啓動數據庫,但只允許具有一定特權的用戶訪問
非特權用戶訪問時,會出現以下提示:
ERROR:
ORA-01035: ORACLE 只允許具有 RESTRICTED SESSION 權限的用戶使用
強制啓動方式 bitsCN.com中國網管聯盟
當不能關閉數據庫時,可以用startup force來完成數據庫的關閉
先關閉數據庫,再執行正常啓動數據庫命令
帶初始化參數文件的啓動方式
先讀取參數文件,再按參數文件中的設置啓動數據庫
例:startup pfile=E:Oracleadminoradbpfileinit.ora
二、用戶如何有效地利用數據字典
ORACLE的數據字典是數據庫的重要組成部分之一,它隨着數據庫的產生而產生, 隨着數據庫的變化而變化,體現爲sys用戶下的一些表和視圖。數據字典名稱是大寫的英文字符。
數據字典裏存有用戶信息、用戶的權限信息、所有數據對象信息、表的約束條件、統計分析數據庫的視圖等。
我們不能手工修改數據字典裏的信息。
很多時候,一般的ORACLE用戶不知道如何有效地利用它。
dict_column 全部數據字典表裏字段名稱和解釋
table_name='USER_INDEXES';
查看當前用戶的缺省表空間
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;
查看用戶下所有的表
SQL>select * from user_tables;
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');
SQL>select table_name,cache from user_tables where
instr(cache,'Y')>0;
查看索引個數和類別
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');
查看序列號,last_number是當前值
SQL>select * from user_sequences;
查看視圖的名稱
SQL>select view_name from user_views;
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');
查看同義詞的名稱
SQL>select * from user_synonyms;
查看某表的約束條件
SQL>select constraint_name,
constraint_type,search_condition, r_constraint_name
from user_constraints where table_name =
upper('&table_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;
查看函數和過程的狀態
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');
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;
select tablespace_name, file_id, file_name,
round(bytes/(1024*1024),0) total_space
from dba_data_files
order by tablespace_name;
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 ;
select name from v$controlfile;
select member from v$logfile;
select sum(bytes)/(1024*1024) as free_space,tablespace_name
from dba_free_space
group by tablespace_name;
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;
select owner, object_type, status, count(*) count# from
all_objects group by owner, object_type, status;
Select version FROM Product_component_version
Where SUBSTR(PRODUCT,1,6)='Oracle';
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#';
SQL> select pro.spid from v$session ses,v$process pro where
ses.sid=21 and ses.paddr=pro.addr;
五、SQL*PLUS使用
a、近入SQL*Plus
$sqlplus 用戶名/密碼
SQL>exit
列出全部SQL命令和SQL*Plus命令
SQL>help
列出某個特定的命令的信息
SQL>help 命令名
SQL>DESC 表名
顯示SQL緩衝區命令
SQL>L
首先要將待改正行變爲當前行
SQL>n
用CHANGE命令修改內容
SQL>c/舊/新
重新確認是否已正確
SQL>L
SQL>i
SQL>輸入內容
可以使用DEFINE命令設置系統變量EDITOR來改變文本編輯器的類型,在login.sql文件中定義如下一行
DEFINE_EDITOR=vi
SQL>START test
SQL>@test
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));
DORP TABLE 表名;
例:表刪除將同時刪除表的數據和表的定義
sql>drop table test
完全備份的SH文件:exp_comp.sh
file=/oracle/export/db_comp$rq.dmp"
file=/oracle/export/db_cumu$rq.dmp"
file=/oracle/export/db_incr$rq.dmp"
/var/spool/cron/crontabs/root增加以下內容
一.數據控制語句 (DML) 部分
1.INSERT (往數據表裏插入記錄的語句)
INSERT INTO 表名(字段名1, 字段名2, ……) SELECT (字段名1, 字段名2, ……) FROM 另外的表名;
如果字段值裏包含單引號’ 需要進行字符串轉換, 我們把它替換成兩個單引號''.
字符串類型的字段值超過定義的長度會出錯, 最好在插入前進行長度校驗.
或者用字符串轉換成日期型函數TO_DATE(‘2001-08-01’,’YYYY-MM-DD’)
TO_DATE()還有很多種日期格式, 可以參看ORACLE DOC.
年-月-日 小時:分鐘:秒 的格式YYYY-MM-DD HH24:MI:SS
方法借用ORACLE裏自帶的DBMS_LOB程序包.
CREATE SEQUENCE 序列號的名稱 (最好是表名+序列號標記) INCREMENT BY 1 START WITH 1
MAXVALUE 99999 CYCLE NOCACHE;
其中最大的值按字段的長度來定, 如果定義的自動增長的序列號 NUMBER(6) , 最大值爲999999
TRUNCATE TABLE 表名;
此操作不可回退.
值N超過定義的長度會出錯, 最好在插入前進行長度校驗..
A. 以上SQL語句對錶都加上了行級鎖,
確認完成後, 必須加上事物處理結束的命令 COMMIT 才能正式生效,
否則改變不一定寫入數據庫裏.
如果想撤回這些操作, 可以用命令 ROLLBACK 復原.
應該把它限定在較小 (一萬條記錄) 範圍內,. 否則ORACLE處理這個事物用到很大的回退段.
程序響應慢甚至失去響應. 如果記錄數上十萬以上這些操作, 可以把這些SQL語句分段分次完成,
其間加上COMMIT 確認事物處理.
二.數據定義 (DDL) 部分
1.CREATE (創建表, 索引, 視圖, 同義詞, 過程, 函數, 數據庫鏈接等)
CHAR 固定長度的字符串
VARCHAR2 可變長度的字符串
NUMBER(M,N) 數字型M是位數總長度, N是小數的長度
DATE 日期類型
創建表時要把較小的不爲空的字段放在前面, 可能爲空的字段放在後面
創建表時可以用中文的字段名, 但最好還是用英文的字段名
創建表時可以給字段加上默認值, 例如 DEFAULT SYSDATE
這樣每次插入和修改時, 不用程序操作這個字段都能得到動作的時間
創建表時可以給字段加上約束條件
例如 不允許重複 UNIQUE, 關鍵字 PRIMARY KEY
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;
DROP TABLE 表名 CASCADE CONSTRAINTS;
SELECT字段名1, 字段名2, …… FROM 表名1, [表名2, ……] WHERE 條件;
例如: COUNT(*), MIN(字段名), MAX(字段名), AVG(字段名), DISTINCT(字段名),
TO_CHAR(DATE字段名,'YYYY-MM-DD HH24:MI:SS')
解釋:
IF EXPR1=NULL
RETURN EXPR2
ELSE
RETURN EXPR1
解釋:
IF AA=V1 THEN RETURN R1
IF AA=V2 THEN RETURN R2
..…
ELSE
RETURN NULL
解釋:
字符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 條件] ;
表名1.字段名 = 表名2. 字段名 [ AND ……] ;
表名1.字段名 = 表名2. 字段名(+) [ AND ……] ;
ORDER BY字段名1, 字段名2 DESC;
字段名 LIKE ‘字符串%’ [‘%字符串%’]
1.索引 (INDEX)
CREATE INDEX 索引名ON 表名 ( 字段1, [字段2, ……] );
ALTER INDEX 索引名 REBUILD;
也可以建立多字段的組合索引和基於函數的索引
ORACLE8.0.6字符串可以索引的最大長度爲758 單字節
CREATE VIEW 視圖名AS SELECT …. FROM …..;
ALTER VIEW視圖名 COMPILE;
CREATE SYNONYM同義詞名FOR 表名;
CREATE SYNONYM同義詞名FOR 表名@數據庫鏈接名;
CREATE DATABASE LINK數據庫鏈接名CONNECT TO 用戶名 IDENTIFIED BY 密碼 USING
‘數據庫連接字符串’;
SELECT * FROM GLOBAL_NAME;
1.GRANT 賦於權限
常用的系統權限集合有以下三個:
CONNECT(基本的連接), RESOURCE(程序開發), DBA(數據庫管理)
常用的數據對象權限有以下五個:
ALL ON 數據對象名, SELECT ON 數據對象名, UPDATE ON
數據對象名,
DELETE ON 數據對象名, INSERT ON 數據對象名, ALTER ON 數據對象名
GRANT SELECT ON 表名 TO 用戶名;
GRANT SELECT, INSERT, DELETE ON表名 TO 用戶名1, 用戶名2;
REVOKE SELECT ON 表名 FROM 用戶名;
REVOKE SELECT, INSERT, DELETE ON表名 FROM 用戶名1, 用戶名2;
select orgaddr,destaddr from sm_histable0116 where error_code='63';
bitsCN_com
select sum(Successcount) from tbl_MiddleMt0411 where ServiceType2=111
select sum(successcount),servicetype from tbl_middlemt0411 group by servicetype