用存儲(chǔ)過程不如用觸發(fā)器。。觸發(fā)器檢測(cè)插入、更新和刪除的。
創(chuàng)新互聯(lián)公司長(zhǎng)期為成百上千客戶提供的網(wǎng)站建設(shè)服務(wù),團(tuán)隊(duì)從業(yè)經(jīng)驗(yàn)10年,關(guān)注不同地域、不同群體,并針對(duì)不同對(duì)象提供差異化的產(chǎn)品和服務(wù);打造開放共贏平臺(tái),與合作伙伴共同營(yíng)造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為忻府企業(yè)提供專業(yè)的成都網(wǎng)站設(shè)計(jì)、網(wǎng)站制作、外貿(mào)營(yíng)銷網(wǎng)站建設(shè),忻府網(wǎng)站改版等技術(shù)服務(wù)。擁有十載豐富建站經(jīng)驗(yàn)和眾多成功案例,為您定制開發(fā)。
1)停止所有oracle相關(guān)的服務(wù)
2)卸載oracle
10g數(shù)據(jù)庫服務(wù)器組件
3)手動(dòng)刪除注冊(cè)表中與oracle相關(guān)的內(nèi)容
4)刪除temp目錄下oracle相關(guān)的文件夾
5)檢查“開始”菜單中是否還有oracle程序組,如果有,則將其刪除
6)重新啟動(dòng)計(jì)算機(jī)
7)刪除windows系統(tǒng)安裝磁盤中的program
files\oracle
目錄
8)刪除oracle安裝目錄
壹佰網(wǎng)歡迎你的加入交流
1、創(chuàng)建用戶表空間:
CREATE TABLESPACE test_data
//創(chuàng)建表空間test_data
LOGGING
DATAFILE 'D:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\TEST_DATA01.DBF'
//創(chuàng)建的數(shù)據(jù)文件
SIZE 32M
//初始大小
AUTOEXTEND ON
//數(shù)據(jù)文件自動(dòng)擴(kuò)容
NEXT 32M MAXSIZE 2048M
EXTENT MANAGEMENT LOCAL;
2、刪除表空間,同時(shí)刪除數(shù)據(jù)文件:
drop tablespace test_data including contents and datafiles;
3、創(chuàng)建用戶臨時(shí)表空間:
CREATE TEMPORARY TABLESPACE test_temp
TEMPFILE 'D:\oracle\product\10.2.0\oradata\orcl\test_temp01.dbf'
SIZE 32M
AUTOEXTEND ON
NEXT 32M MAXSIZE 2048M
EXTENT MANAGEMENT LOCAL;
4、創(chuàng)建用戶并指定表空間:
CREATE USER xiaoming IDENTIFIED BY xm123
//創(chuàng)建用戶xiaoming,設(shè)置密碼為xm123
DEFAULT TABLESPACE TEST_DATA
//指定默認(rèn)表空間為test_data
TEMPORARY TABLESPACE TEST_TEMP;
//指定臨時(shí)表空間為test_temp
指定默認(rèn)表空間以后,用戶xiaoming創(chuàng)建的表都在這個(gè)表空間下,除非額外指定;
當(dāng)然,要給用戶xiaoming授權(quán)才能創(chuàng)建表。
方法如下:
一、在oracle11G以前卸載oracle會(huì)存在卸載不干凈,導(dǎo)致再次安裝失敗的情況,在運(yùn)行services.msc打開服務(wù),停止Oracle的所有服務(wù)。
二、 oracle11G自帶一個(gè)卸載批處理\app\Administrator\product\11.2.0\dbhome_1\deinstall\deinstall.bat運(yùn)行該批處理程序?qū)⒆詣?dòng)完成oracle卸載工作,最后手動(dòng)刪除\app文件夾(可能需要重啟才能刪除)
運(yùn)行過程中可能需要填寫如下項(xiàng):
指定要取消配置的所有單實(shí)例監(jiān)聽程序[LISTENER]:LISTENER
指定在此 Oracle 主目錄中配置的數(shù)據(jù)庫名的列表 [MYDATA,ORCL]: MYDATA,ORCL
是否仍要修改 MYDATA,ORCL 數(shù)據(jù)庫的詳細(xì)資料? [n]: n
CCR check is finished
是否繼續(xù) (y - 是, n - 否)? [n]: y
三、運(yùn)行regedit命令,打開注冊(cè)表。刪除注冊(cè)表中與Oracle相關(guān)內(nèi)容,具體下:
刪除HKEY_LOCAL_MACHINE/SOFTWARE/ORACLE目錄。
刪除HKEY_LOCAL_MACHINE/SYSTEM/CurrentControlSet/Services中所有以oracle或OraWeb為開頭的鍵。
刪除HKEY_LOCAL_MACHINE/SYSETM/CurrentControlSet/Services/Eventlog/application中所有以oracle開頭的鍵。
刪除HKEY_CLASSES_ROOT目錄下所有以O(shè)ra、Oracle、Orcl或EnumOra為前綴的鍵。
刪除HKEY_CURRENT_USER/SOFTWARE/Microsoft/windows/CurrentVersion/Explorer/MenuOrder/Start Menu/Programs中所有以oracle 開頭的鍵。
刪除HKDY_LOCAL_MACHINE/SOFTWARE/ODBC/ODBCINST.INI中除Microsoft ODBC for Oracle注冊(cè)表鍵以外的所有含有Oracle的鍵。
刪除環(huán)境變量中的PATHT CLASSPATH中包含Oracle的值。
刪除“開始”/“程序”中所有Oracle的組和圖標(biāo)。
刪除所有與Oracle相關(guān)的目錄,包括:
(1)、c:\Program file\Oracle目錄。 (2)、ORACLE_BASE目錄。(3)、c:\Documents and Settings\系統(tǒng)用戶名、LocalSettings\Temp目錄下的臨時(shí)文件。
開始--運(yùn)行 輸入regedit
編輯--查找 輸入oracle, 如沒有找到相關(guān)內(nèi)容,則表示卸載干凈。
如注冊(cè)表中還有相關(guān)記錄則刪除,電腦中有關(guān)oracle的目錄也一并刪除。
可以查看oracle日志:
Oracle日志查看
一.Oracle日志的路徑:
登錄:sqlplus "/as sysdba"
查看路徑:SQL select * from v$logfile;
SQL select * from v$logfile;(#日志文件路徑)
二.Oracle日志文件包含哪些內(nèi)容:(日志的數(shù)量可能略有不同)
control01.ctl example01.dbf redo02.log sysaux01.dbf undotbs01.dbf
control02.ctl redo03.log system01.dbf users01.dbf
control03.ctl redo01.log SHTTEST.dbf temp01.dbf
三.Oracle日志的查看方法:
SQLselect * from v$sql (#查看最近所作的操作)
SQLselect * fromv $sqlarea(#查看最近所作的操作)
Oracle 數(shù)據(jù)庫的所有更改都記錄在日志中,從目前來看,分析Oracle日志的唯一方法就是使用Oracle公司提供的LogMiner來進(jìn)行,因?yàn)樵嫉娜罩拘畔⑽覀兏緹o法看懂,Oracle8i后續(xù)版本中自帶了LogMiner,而LogMiner就是讓我們看懂日志信息的工具,通過這個(gè)工具可以:查明數(shù)據(jù)庫的邏輯更改,偵察并更正用戶的誤操作,執(zhí)行事后審計(jì),執(zhí)行變化分析。
四.LogMiner的使用:
1、創(chuàng)建數(shù)據(jù)字典文件(data-dictionary)
1).首先在init.ora初始化參數(shù)文件中,添加一個(gè)參數(shù)UTL_FILE_DIR,該參數(shù)值為服務(wù)器中放置數(shù)據(jù)字典文件的目錄。如:UTL_FILE_DIR = ($ORACLE_HOME\logs) ,重新啟動(dòng)數(shù)據(jù)庫,使新加的參數(shù)生效:
SQL shutdown;
SQLstartup;
2).然后創(chuàng)建數(shù)據(jù)字典文件
SQL connect /as sysdba
SQL execute dbms_logmnr_d.build(dictionary_filename = 'dict.ora',dictionary_location = '/data1/oracle/logs');
PL/SQL procedure successfully completed
2、創(chuàng)建要分析的日志文件列表
1).創(chuàng)建分析列表,即所要分析的日志
SQLexecute dbms logmnr.add logfile(LogFileName = '/data1/oracle/oradata/akazamdb/redo01.log',Options = dbms_logmnr.new);
PL/SQL procedure successfully completeds
2).添加分析日志文件,一次添加1個(gè)為宜
SQLexecute dbms_ logmnr.add_ logfile(LogFileName = '/data1/oracle/oradata/akazamdb/redo01.log',Options = dbms_logmnr.ADDFILE);
PL/SQL procedure successfully completed
3、使用LogMiner進(jìn)行日志分析(具體要查詢什么內(nèi)容可以自己修改)
(1)無限制條件
SQL EXECUTE dbms_logmnr.start_logmnr(
DictFileName='/data1/oracle/logs/v816dict.ora ');
(2)有限制條件
通過對(duì)過程DBMS_ LOGMNR.START_LOGMNR中幾個(gè)不同參數(shù)的設(shè)置,可以縮小要分析日志文件的范圍。通過設(shè)置起始時(shí)間和終止時(shí)間參數(shù)我們可以限制只分析某一時(shí)間范圍的日志。如下面的例子,我們僅僅分析2007年9月18日的日志:
SQL EXECUTE dbms_logmnr.start_logmnr(
DictFileName = ' /data1/oracle/logs/ v816dict.ora ',
StartTime = to_date('2007-9-18 00:00:00','YYYY-MM-DD HH24:MI:SS')
EndTime = to_date(''2007-9-18 23:59:59','YYYY-MM-DD HH24:MI:SS '));
也可以通過設(shè)置起始SCN和截至SCN來限制要分析日志的范圍:
SQL EXECUTE dbms_logmnr.start_logmnr(
DictFileName = ' /data1/oracle/logs/ v816dict.ora ',
StartScn = 20,
EndScn = 50);
4、觀察分析結(jié)果(v$logmnr_contents)
到現(xiàn)在為止,我們已經(jīng)分析得到了重作日志文件中的內(nèi)容。動(dòng)態(tài)性能視圖v$logmnr_contents包含LogMiner分析得到的所有的信息。
SELECT sql_redo FROM v$logmnr_contents;
如果我們僅僅想知道某個(gè)用戶對(duì)于某張表的操作,可以通過下面的SQL查詢得到,該查詢可以得到用戶DB_ZGXT對(duì)表SB_DJJL所作的一切工作。
SQL SELECT sql_redo FROM v$logmnr_contents WHERE username='DB_ZGXT' AND tablename='SB_DJJL';
需要強(qiáng)調(diào)一點(diǎn)的是,視圖v$logmnr_contents中的分析結(jié)果僅在我們運(yùn)行過程'dbms_logmrn.start_logmnr'這個(gè)會(huì)話的生命期中存在。這是因?yàn)樗械腖ogMiner存儲(chǔ)都在PGA內(nèi)存中,所有其他的進(jìn)程是看不到它的,同時(shí)隨著進(jìn)程的結(jié)束,分析結(jié)果也隨之消失。
最后,使用過程DBMS_LOGMNR.END_LOGMNR終止日志分析事務(wù),此時(shí)PGA內(nèi)存區(qū)域被清除,分析結(jié)果也隨之不再存在。
5、查看LogMiner工具分析結(jié)果
SQL select * from dict t where t.table_name like '%LOGMNR%';-看所有與logmnr相關(guān)的視圖
TABLE_NAME COMMENTS
------------------------------ --------------------------------------------------------------------------------
GV$LOGMNR_CALLBACK Synonym for GV_$LOGMNR_CALLBACK
GV$LOGMNR_CONTENTS Synonym for GV_$LOGMNR_CONTENTS
GV$LOGMNR_DICTIONARY Synonym for GV_$LOGMNR_DICTIONARY
GV$LOGMNR_LOGFILE Synonym for GV_$LOGMNR_LOGFILE
GV$LOGMNR_LOGS Synonym for GV_$LOGMNR_LOGS
GV$LOGMNR_PARAMETERS Synonym for GV_$LOGMNR_PARAMETERS
GV$LOGMNR_PROCESS Synonym for GV_$LOGMNR_PROCESS
GV$LOGMNR_REGION Synonym for GV_$LOGMNR_REGION
GV$LOGMNR_SESSION Synonym for GV_$LOGMNR_SESSION
GV$LOGMNR_STATS Synonym for GV_$LOGMNR_STATS
GV$LOGMNR_TRANSACTION Synonym for GV_$LOGMNR_TRANSACTION
V$LOGMNR_CALLBACK Synonym for V_$LOGMNR_CALLBACK
V$LOGMNR_CONTENTS Synonym for V_$LOGMNR_CONTENTS
V$LOGMNR_DICTIONARY Synonym for V_$LOGMNR_DICTIONARY
V$LOGMNR_LOGFILE Synonym for V_$LOGMNR_LOGFILE
V$LOGMNR_LOGS Synonym for V_$LOGMNR_LOGS
V$LOGMNR_PARAMETERS Synonym for V_$LOGMNR_PARAMETERS
V$LOGMNR_PROCESS Synonym for V_$LOGMNR_PROCESS
V$LOGMNR_REGION Synonym for V_$LOGMNR_REGION
V$LOGMNR_SESSION Synonym for V_$LOGMNR_SESSION
TABLE_NAME COMMENTS
------------------------------ --------------------------------------------------------------------------------
V$LOGMNR_STATS Synonym for V_$LOGMNR_STATS
V$LOGMNR_TRANSACTION Synonym for V_$LOGMNR_TRANSACTION
GV$LOGMNR_LOGS 是分析日志列表視圖
分析結(jié)果在GV$LOGMNR_CONTENTS 視圖中,可按以下語句查詢:
select scn,timestamp,log_id,seg_owner,seg_type,table_space,data_blk#,data_obj#,data_objd#,
session#,serial#,username,session_info,sql_redo,sql_undo from logmnr3 t where t.sql_redo like 'create%';
如果不能正常查詢GV$LOGMNR_CONTENTS視圖,并報(bào)以下錯(cuò)誤,ORA-01306: 在從 v$logmnr_contents 中選擇之前必須調(diào)用 dbms_logmnr.start_logmnr() ??刹捎萌缦路椒ǎ?/p>
create table logmnr3 as select * from GV$LOGMNR_CONTENTS;
Oracle端口:1521