資料庫實例啟動
1. ORACLE資料庫啟動與關閉的步驟
oracle的啟動和關閉
一、sql*plus方式:
用sql*plus來連接到Oracle
Sqlplus /nolog 是以不連接資料庫的方式啟動sql*plus
Connect /as sysdba 是以DBA身份連接到oracle
or35.gif
. 啟動
or36.gif
Startup就可以啟動了。
不過oracle啟動模式有3種:
l Startup nomount (nomount模式)啟動實例不載入資料庫。
l Startup mount (mount模式)啟動實例載入資料庫但不打開資料庫
l Startup (open 模式)啟動實例載入並打開資料庫,就是我們上面所用的命令
Nomount模式中oracle僅為實例創建各種內存結構和服務進程,不會打開任何資料庫文件,
所以說:
1) 創建新資料庫
2) 重建控制文件
這2種操作都必須在這個模式下進行。
Mount模式中oracle只裝載資料庫但不打開資料庫,所以說:
1) 重命名數據文件
2) 添加、刪除和重命名重做日子文件
3) 執行資料庫完全恢復操作
4) 改變資料庫的歸檔模式
這4種操作都必須在這個模式下進行
Open模式(就是我們上面的startup不帶任何參數的)正常啟動。
當然這3種模式之間可以轉換:
Alter database mount(nomount模式)—〉alter database open(mount 模式)—〉(open模式)
當然還有其它一些情況,在我們open模式下可以將資料庫設置為非受限狀態和受限狀態
在受限狀態下,只有DBA才能訪問資料庫,所以說:
1) 執行數據導入導出
2) 使用sql*loader提取外部數據
3) 需要暫時拒絕普通用戶訪問資料庫
4) 進行資料庫移植或者升級操作
這4種操作都必須在這個狀態下進行
在打開資料庫時使用startup restrict命令即進入受限狀態。
or37.gif
使用alter system disable restricted session命令即可以將受限狀態改變為非受限狀態。
or38.gif
使用alter system enable restricted session命令可以將非受限狀態變為受限狀態
or39.gif
使用alter database open read only可以使資料庫進入只讀狀態。
使用alter database open read write 可以使資料庫進入讀寫狀態。
當然在某些情況下可能是用上述各種啟動方式都無法成功啟動資料庫,這個時候就要使用startup force命令來強行啟動資料庫。當然誰都不想碰到這種情況:)
or40.gif
c.關閉資料庫
1)正常關閉 shutdown
2) 立即關閉 shutdown immediate
3) 關閉事務 shutdown transactional
4) 強行關閉 shutdown abort,當然誰都不想碰到這種情況。
二、OEM為例
Oracle Enterprise Management(OEM),
跟第一小節講的Sqlplus /nolog ,Connect /as sysdba 這2個命令差不多的操作如圖:
or29.gif
or30.gif
or31.gif
按照上面的一步步操作就能夠連接到資料庫。
下面是如何啟動和關閉資料庫:
or32.gif
點擊我們前幾章創建的ORADB01這個資料庫樹中的配置選項,這個裡面的:
1)已啟動 對應 Nomount模式
2)已轉載 對應 mount模式
3)打開 對應 open模式
當你點擊應有按鈕之後就會進入如下對話框
or33.gif
1)正常 對應 正常關閉 shutdown
2) 立即 對應 立即關閉 shutdown immediate
3) 事務處理 對應 關閉事務 shutdown transactional
4) 中止 對應 強行關閉 shutdown abort
確定之後出現如下對話框
or34.gif
限制對資料庫訪問 對應 alter system disable restricted session
alter system enable restricted session
只讀模式 對應 alter database open read only
alter database open read write
簡單吧,sql*plus的一大堆命令到OEM中變成了幾個按鈕罷了。
3.windows控制台
or41.gif
這個熟悉吧:
oracle ************Agent 用於OEM管理結構
oracle************HTTPSERVER oracle Web伺服器
oracle ************ManagementServer 用於OEM管理結構
oracle ************ TNSListener oracle網路結構的伺服器端進程
oracle ************OEMREP 資料檔案庫文件
oracle ************ORADB001 用戶創建的資料庫
我一般都把所有的服務全部選成手動啟動,如果全開,內存要用掉700M.............
2. DB2怎麼啟動資料庫
1、 打開命令行窗口
#db2cmd
2、 打開控制中心
# db2cmd db2cc
3、 打開命令編輯器
db2cmd db2ce
=====操作資料庫命令=====
4、 啟動資料庫實例
#db2start
5、 停止資料庫實例
#db2stop
如果你不能停止資料庫由於激活的連接,在運行db2stop前執行db2
force application all就可以了 /db2stop force
6、 創建資料庫
#db2 create db
[dbname]
7、 連接到資料庫
#db2 connect to [dbname] user [username] using
[password]
8、 斷開資料庫連接
#db2 connect reset
9、 列出所有資料庫
#db2 list
db directory
10、 列出所有激活的資料庫
#db2 list active databases
11、
列出所有資料庫配置
#db2 get db cfg
12、 刪除資料庫
#db2 drop database [dbname]
(執行此操作要小心)
如果不能刪除,斷開所有資料庫連接或者重啟db2
=========操作數據表命令==========
13、 列出所有用戶表
#db2 list tables
14、列出所有系統表
#db2 list tables for
system
15、列出所有表
#db2 list tables for all
16、 列出系統表
#db2 list
tables for system
17、列出用戶表
#db2 list tables for user
18、 列出特定用戶表
#db2 list tables for schema [user]
19、 創建一個與資料庫中某個表(t2)結構相同的新表(t1)
#db2 create table t1 like t2
20、 將一個表t1的數據導入到另一個表t2
#db2 "insert
into t1 select * from t2"
21、 查詢表
#db2 "select * from table name where
..."
22、 顯示表結構
#db2 describe table tablename
23、 修改列
#db2
alter table [tablename] alter column [columname] set data type varchar(24)
======腳本文件操作命令=======
24、 執行腳本文件
#db2 -tvf scripts.sql
25、幫助命令
* 查看命令幫助
#db2 ? db2start
* 查看錯誤碼信息
#db2 ? 22001
* memo:
詳細命令請使用"db2 ? <command>"進行查看。
=========================
26、備份資料庫
#db2 backup db <db name>
備註:執行以上命令之前需要斷開資料庫連接
27、在線備份資料庫
#db2 -v "BACKUP DATABASE <database name> ONLINE TO <path> WITH 2
BUFFERS BUFFER 1024 INCLUDE LOGS WITHOUT PROMPTING"
28、恢復資料庫
#db2
restore db <source db name>
29、在線恢復資料庫
#db2 "RESTORE DB
<database name> TO <db path> LOGTARGET <logpath> WITHOUT
PROMPTING"
#db2 "ROLLFORWARD DB <database name> TO END OF LOGS AND
STOP" ...
30、導出數據文件
#db2move <db name> export
[-sn
<模式名稱,一般為db2admin>]
[-tn <表名,多個之間用逗號分隔>]
31、導入數據文件
#db2move <db name> import
32、獲取db2資料庫管理配置環境信息
#db2 get dbm cfg
33、.獲取db2某個資料庫資料庫管理配置環境信息
#db2 get db cfg for <db name>
或者:連接至某個資料庫以後執行db2 get db cfg
34、更改db2日誌空間的大小
備註:以下命令為了防止db2資料庫過份使用硬碟空間而設,僅用於開發者自己機器上的db2,如果是伺服器,則參數需要修改。
#db2
UPDATE DB CFG FOR <db name> USING logretain OFF logprimary 3 logsecond 2
logfilsiz 25600;
如果頁大小是4KB,則以上命令創建3個100M的日誌文件,佔用300MB硬碟空間。25600*4KB=102400KB。
35、創建臨時表空間
#DB2 CREATE USER TEMPORARY TABLESPACE STMASPACE PAGESIZE 32 K MANAGED BY
DATABASE USING (FILE 'D:\DB2_TAB\STMASPACE.F1' 10000)
EXTENTSIZE 256
36、獲取資料庫管理器的快照數據
#db2 –v get snapshot for dbm
37、顯示進行程號
#db2
list applications show detail
===================================================
一、載入數據:
1、
以默認分隔符載入,默認為「,」號
db2 "import from btpoper.txt of del insert into btpoper"
2、 以指定分隔符「|」載入
db2 "import from btpoper.txt of del modified by coldel|
insert into btpoper"
二、卸載數據:
1、 卸載一個表中全部數據
db2 "export to
btpoper.txt of del select * from btpoper"
db2 "export to btpoper.txt of del
modified by coldel| select * from btpoper"
2、 帶條件卸載一個表中數據
db2 "export to
btpoper.txt of del select * from btpoper where brhid='907020000'"
db2
"export to cmmcode.txt of del select * from cmmcode where codtp='01'"
db2
"export to cmmcode.txt of del modified by coldel| select * from cmmcode where
codtp='01'"
三、查詢數據結構及數據:
db2 "select * from btpoper"
db2 "select *
from btpoper where brhid='907020000' and oprid='0001'"
db2 "select
oprid,oprnm,brhid,passwd from btpoper"
四、刪除表中數據:
db2 "delete from
btpoper"
db2 "delete from btpoper where brhid='907020000' or
brhid='907010000'"
五、修改表中數據:
db2 "update svmmst set prtlines=0 where
brhid='907010000' and jobtp='02'"
db2 "update svmmst set prtlines=0 where
jobtp='02' or jobtp='03'"
六、聯接資料庫
db2 connect to btpdbs
七、清除資料庫聯接
db2 connect reset 斷開資料庫連接
db2 terminate 斷開資料庫連接
db2 force
applications all 斷開所有資料庫連接
八、備份資料庫
1、 db2 backup db btpdbs
2、
db2move btpdbs export
db2look -d btpdbs -e -x [-a] -o crttbl.sql
九、恢復資料庫
1、 db2 restore db btpdbs without rolling forward
2、 db2 -tvf crtdb.sql
crtdb.sql文件內容:create db btpdbs on /db2catalog
db2 -stvf crttbl.sql
db2move btpdbs import
十、DB2幫助命令:
db2 ?
db2 ? restroe
db2 ?
sqlcode (例:db2 ? sql0803) 註:code必須為4位數,不夠4位,前面補0
十一、bind命令:將應用程序與資料庫作一捆綁,每次恢復資料庫後,建議都要做一次bind
(1) db2 bind br8200.bnd
(2) /btp/bin/bndall /btp/bnd
/btp/bin/bndall /btp/tran/bnd
十二、查看資料庫參數:
db2 get dbm cfg
db2 get db cfg for btpdbs
十三、修改資料庫參數:
db2 update db cfg for btpdbs using LOGBUFSZ 20
db2
update db cfg for btpdbs using LOGFILSIZ 5120
改完後,應執行以下命令使其生效:
db2 stop
db2 start
3. linux 啟動停止oracle實例+如何啟動多個實例
啟動資料庫實例,分為兩步: 第一步,啟動監聽; [oracle@wuzhq ~]$ su - oracle --「切換到oracle用戶」 [oracle@wuzhq ~]$ lsnrctl start --「打開監聽」 第二步,啟動資料庫實例。 [oracle@wuzhq ~]$ sqlplus /nolog --「進入到sqlplus」 SQL> conn /as sysdba --「連接到sysdba」 SQL> startup --「啟動資料庫實例」 關閉資料庫實例: SQL> shutdown immediate --「關閉資料庫實例」SQL> exit[oracle@redhat ~]$ lsnrctl stop========================================= 假如你的伺服器上有DB1和DB2兩個實例,且這兩個實例都是由同一個操作系統用戶創建的,用此操作系統用戶登錄到伺服器,執行 export ORACLE_SID=DB1 sqlplus /nolog connect / as sysdba startup exit EOF export ORACLE_SID=DB2 sqlplus /nolog connect / as sysdba startup exit ==========================================sqlplus / as sysdbastartuppfile=$ORACLE_HOME/dbs/initDB1.oraexitsqlplus / as sysdbastartuppfile=$ORACLE_HOME/dbs/initDB2.oraexit
4. oracle怎麼查看資料庫實例是否啟動
如果是windows下裝的資料庫,只要去看資料庫服務是否啟動就可以了;
linux下要先進入oracle用戶,橋status命令就可以查看了
5. 怎樣啟動和關閉oracle資料庫
1、由於oracle運行在Linux系統裡面,第一步,我們要連接Linux系統。