1. 程式人生 > >Oracle協議介面卡錯誤解決辦法

Oracle協議介面卡錯誤解決辦法

在Oracle中新建了一個數據庫,今天把它刪了之後再登入SQL*PLUS就登不上去了,出現ORA-12560:TNS:協議介面卡錯誤。


  ORA-12560: TNS: 協議介面卡錯誤的解決方法


  造成ORA-12560: TNS: 協議介面卡錯誤的問題的原因有三個:


  1.監聽服務沒有起起來。windows平臺個一如下操作:開始---程式---管理工具---服務,開啟服務面板,啟動oraclehome92TNSlistener服務。


  2.database instance沒有起起來。windows平臺如下操作:開始---程式---管理工具---服務,開啟服務面板,啟動oracleserviceXXXX,XXXX就是你的database SID.


  3.登錄檔問題。regedit,然後進入HKEY_LOCAL_MACHINE\SOFTWARE\ORACLE\HOME0將該環境變數ORACLE_SID設定為XXXX,XXXX就是你的database SID.或者右幾我的電腦,屬性--高階--環境變數---系統變數--新建,變數名=oracle_sid,變數值=XXXX,XXXX就是你的database SID.或者進入sqlplus前,在command line下輸set oracle_sid=XXXX,XXXX就是你的database SID.


  經過以上步驟,就可以解決問題。


  =======================================


  1、ORA-12541:TNS:沒有監聽器


  原因:沒有啟動監聽器或者監聽器損壞。如果是前者,使用命令net start OracleOraHome81TNSListener(名字可能有出入)即可;如果是後者,則使用“Net8 Configuration


  Assistant”工具嚮導之“監聽程式配置”增加一個監聽器即可(基本不用寫任何資訊,一路OK。在新增之前可能需要把所有的監聽器先刪除!)


  2、ORA-12500:TNS:監聽程式無法啟動專用伺服器程序或ORA-12560:TNS:協議介面卡錯誤


  原因:ORACLE的資料庫服務沒有啟動。使用命令net start ORACLESERVICEORADB(ORADB為資料庫名字)即可。如果仍沒有解決,請繼續向下看。


  3、如果資料庫服務啟動失敗,則很有可能是其登錄檔項值損壞,最好的做法是以下兩步:


  1)ORADIM -DELETE -SID oradb 刪除資料庫服務項


  2)ORADIM -NEW -SID oradb 新增資料庫服務項


  注:這個過程中如果出錯,就重啟計算機!


  4、ORA-12154:TNS:能解析服務名


  原因:ORACLE的網路服務名沒有正確配置。請使用“Net8 Configuration Assistant”工具嚮導之“本地網路服務名配置”配置TNS即可。如果仍沒有解決,請繼續向下看。


  5、ORA-1034 :TNS:ORACLE不可用


  原因:ORACLE的資料庫服務正確啟動,但是資料庫沒有開啟!


  使用命令:


  1)svrmgrl 啟動服務管理器


  2)connect internal 以internal身份登陸


  3)startup 開啟資料庫


  6、ORA-12560:TNS:協議介面卡錯誤(頑固性的)


  原因:未知。


  解決:必殺技--開啟“Windows工作管理員”,殺死ORACLE.exe及ORADIM.exe程序,書寫自己的


  ora_startup.bat,執行之!


  PS:


  1、我的ora_startup.bat:


  net start OracleOraHome81TNSListener


  net start ORACLESERVICEORADB


  svrmgrl 一般情況下不用,不過有時少不了它的,具體步驟見第5步。


  2、我的ora_shutdown.bat:


  net stop OracleOraHome81TNSListener


  net stop ORACLESERVICEORADB


  ORACLE_HOME=/u01/app/oracle/product/8.1.6


  export ORACLE_HOME/ 包括Oracle軟體的目錄 /


  LD_LIBRARY_PATH=/u01/app/oracle/product/8.1.6/lib;


  export LD_LIBRARY_PATH


  ORACLE_BASE=/u01/app/oracle


  export ORACLE_BASE/ 包括Oracle軟體的目錄和管理軟體的目錄 /


  ORACLE_SID=ORCL


  export ORACLE_SID/ 預設資料庫的標識 /


  ORACLE_TERM=vt100


  export ORACLE_TERM


  ORA_NLS33=/u01/app/oracle/product/8.1.6/


  ocommon/nls/admin/data


  export ORA_NLS33 / 語言支援 /


  PATH=$PATH: /u01/app/oracle/product/8.1.6/bin


  export PATH