程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> DB2數據庫 >> DB2教程 >> DB2數據庫使用

DB2數據庫使用

編輯:DB2教程

1.使用db2cmd打開db2命令行
 
2.db2look -d db_name -e -a -x -i db_username -w db_passwd -0 file_name.sql #導出數據庫結構
 
3.db2move db_name export -u db_username -p db_passwd #導出數據庫數據
 
4. create database db_name on 'directory_name' using codeset utf-8 territory US collate using system; # IBM-eucJP --一種編碼格式
 
5.create schema sch_name authorization sch_passwd;#設置權限
 
6.db2 connect to db_name user username using db_passwd #連接數據庫
 
7.db2 -tvf 'file_name'# -f 讀取輸入文件-t 終止語句字符-v 回送當前命令如果文件中每個語句是直接以回車結尾,則用-vf即可,加上-t是表示沒條語句以";"結尾
 
8.DB2數據庫備份
 
cmd--->db2cmd--->db2
db stop force 防止有人在應用(應該db2stop force)
db start (應該db2start)
//connect to wjm_mis user wyn using wyn(重新連接後,表示在使用,不能備份)
backup db wjm_cms to c:\
9、在新的db2導入數據
 
創建數據庫: db2 create db 庫名
 
導入表結構操作:db2 -tvf 文件名.sql
 
導入數據操作:db2move 新建庫名load
 
我們用db2look命令得到數據庫對象的DDL 腳本
DB2的db2look命令诠釋如下:
db2look 版本8.2
db2look:生成DDL 以便重新創建在數據庫中定義的對象
語法: db2look -d DBname [-e] [-u Creator] [-z Schema] [-t Tname1 Tname2...TnameN] [-tw Tname] [-h] [-o Fname] [-a]
                        [-m] [-c] [-r] [-l] [-x] [-xd] [-f] [-fd] [-td x] [-noview] [-i userID] [-w password]
                        [-v Vname1 Vname2 ... VnameN]
                        [-wrapper WrapperName] [-server ServerName] [-nofed]
 
      db2look -d DBname [-u Creator] [-s] [-g] [-a] [-t Tname1 Tname2...TnameN]
                        [-p] [-o Fname] [-i userID] [-w password]
      db2look [-h]
 
        -d: 數據庫名稱:這必須指定
 
        -e: 抽取復制數據庫所需要的DDL 文件
            此選項將生成包含DDL 語句的腳本
            可以對另一個數據庫運行此腳本以便重新創建數據庫對象
            此選項可以和-m 選項一起使用
        -u: 創建程序標識:若-u 和-a 都未指定,則將使用$USER
            如果指定了-a 選項,則將忽略-u 選項
        -z: 模式名:如果同時指定了-z 和-a,則將忽略-z
            聯合部分的模式名被忽略
        -t: 生成指定表的統計信息
            可以指定的表的數目最多為30
        -tw: 為名稱與表名的模式條件(通配符)相匹配的表生成DDL
            當指定了-tw 選項時,-t 選項會被忽略
        -v: 只為視圖生成DDL,當指定了-t 時將忽略此選項
        -h: 更詳細的幫助消息
        -o: 將輸出重定向到給定的文件名
            如果未指定-o 選項,則輸出將轉到stdout
        -a: 為所有創建程序生成統計信息
            如果指定了此選項,則將忽略-u 選項
        -m: 在模擬方式下運行db2look 實用程序
            此選項將生成包含SQL UPDATE 語句的腳本
            這些SQL UPDATE 語句捕獲所有統計信息
            可以對另一個數據庫運行此腳本以便復制初始的那一個
            當指定了-m 選項時,將忽略-p、-g 和-s 選項
         -c: 不要生成模擬的COMMIT 語句
            除非指定了-m 或-e,否則將忽略此選項
            將不生成CONNECT 和CONNECT RESET 語句
            省略了COMMIT。在執行腳本之後,需要顯式地進行落實。
         -r: 不要生成模擬的RUNSTATS 語句
            缺省值為 RUNSTATS。僅當指定了-m 時,此選項才有效
        -l: 生成數據庫布局:數據庫分區組、緩沖池和表空間。
        -x: 如果指定了此選項,則db2look 實用程序將生成授權DDL
            對於現有已授權特權,不包括對象的原始定義器
        -xd: 如果指定了此選項,則db2look 實用程序將生成授權DDL
            對於現有已授權特權,包括對象的原始定義器
        -f: 抽取配置參數和環境變量
            如果指定此選項,將忽略-wrapper 和-server 選項
        -fd: 為opt_buffpage 和opt_sortheap 以及其它配置和環境參數生成db2fopt 語句。
       -td: 將x 指定為語句定界符(缺省定界符為分號(;))
            應該與-e 選項一起使用(如果觸發器或者SQL 例程存在的話)
        -p: 使用明文格式
        -s: 生成postscript 文件
            此選項將為您生成postscript 文件
            當設置了此選項時,將除去所有latex 和tmp ps 文件
            所需的(非IBM)軟件:LaTeX 和dvips
            注意:文件psfig.tex 必須在LaTeX 輸入路徑中
        -g: 使用圖形來顯示索引的頁訪存對
            必須安裝Gnuplot,並且<psfig.tex> 必須在您的LaTeX 輸入路徑中
            還將隨LaTeX 文件一起生成<filename.ps> 文件
        -i: 登錄到數據庫駐留的服務器時所使用的用戶標識
        -w: 登錄到數據庫駐留的服務器時所使用的密碼
   -noview: 不要生成CREATE VIEW ddl 語句
-wrapper: 為適用於此包裝器的聯合對象生成DDL
            生成的對象可能包含下列各項:
            包裝器、服務器、用戶映射、昵稱、類型映射、
            函數模板、函數映射和索引規范
   -server: 為適用於此服務器的聯合對象生成DDL
            生成的對象可能包含下列各項:
            包裝器、服務器、用戶映射、昵稱、類型映射、
            函數模板、函數映射和索引規范
    -nofed: 不要生成Federated DDL
            如果指定此選項,將忽略-wrapper 和-server 選項
 
LaTeX 排版:latex filename.tex 以獲得filename.dvi
 
示例: db2look -d DEPARTMENT -u walid -e -o db2look.sql
 
-- 這將生成由用戶WALID 創建的所有表和聯合對象的DDL 語句
-- db2look 輸出被發送到名為db2look.sql 的文件中
 
示例: db2look -d DEPARTMENT -z myscm1 -e -o db2look.sql
 
-- 這將為模式名為MYSCM1 的所有表生成DDL 語句
-- 還將生成$USER 創建的所有聯合對象的DDL。
-- db2look 輸出被發送到名為db2look.sql 的文件中
 
示例: db2look -d DEPARTMENT -u walid -m -o db2look.sql
 
-- 這將生成UPDATE 語句以捕獲關於用戶WALID 創建的表/昵稱的統計信息
-- db2look 輸出被發送到名為db2look.sql 的文件中
 
示例: db2look -d DEPARTMENT -u walid -e -wrapper W1 -o db2look.sql
 
-- 這將生成由用戶WALID 創建的所有表的DDL 語句
-- 還將生成適用於包裝器W1 的用戶WALID 所創建所有聯合對象的DDL
-- db2look 輸出被發送到名為db2look.sql 的文件中
 
示例: db2look -d DEPARTMENT -u walid -e -server S1 -o db2look.sql
 
-- 這將生成由用戶WALID 創建的所有表的DDL 語句
-- 還將生成適用於服務器S1 的用戶WALID 所創建所有聯合對象的DDL
-- db2look 輸出被發送到名為db2look.sql 的文件中
 
 
 
 
 
 
 
 
 
 
方法一
 
在控制中心的對象視圖窗口中,選擇所要導出表結構的數據表,按住Ctrl或Shift可多選,單擊鼠標右鍵,選擇->生成DDL即可。
 
方法二
 
◆第一步:打開DB2的命令行工具,在DB2安裝目錄的BIN文件夾下新建一個文件夾data,並且進入該目錄。
 
創建該目錄:mkdir data
進入該目錄:cd data
 
◆第二步:導出表結構,命令行如下:
db2look -d dbname -e -a -x -i username -w password -o ddlfile.sql
 
 
執行成功之後,你會在剛才新建的文件夾下找到該sql文件。
 
◆第三步:導出數據,命令行如下:
db2move databasename export -u username -p password
 
 
 
至此,導出數據結束。
 
2導出表中數據
 
export to [path(例:D:"TABLE1.ixf)] of ixf select [字段(例: * or col1,col2,col3)] from TABLE1;
 
export to [path(例:D:"TABLE1.del)] of del select [字段(例: * or col1,col2,col3)] from TABLE1;
 
導入表的數據
 
import from [path(例:D:"TABLE1.ixf)] of ixf insert into TABLE1;
 
load from [path(例:D:"TABLE1.ixf)] of ixf insert into TABLE1;
 
load from [path(例:D:"TABLE1.ixf)] of ixf replace into TABLE1; // 裝入數據前,先刪除已存在記錄
 
load from [path(例:D:"TABLE1.ixf)] of ixf restart into TABLE1; // 當裝入失敗時,重新執行,並記錄導出結果和錯誤信息
 
import from [path(例:D:"TABLE1.ixf)] of ixf savecount 1000 messages [path(例:D:"msg.txt)] insert into TABLE1;// 其中,savecount表示完成每1000條操作,記錄一次.
 
存在自增長字段的數據導入:
 
load from [path(例:D:"TABLE1.ixf)] of ixf modified by identityignore insert into TABLE1;// 加入modified by identityignore.
 
解除裝入數據時,發生的檢查掛起:
 
SET INTEGRITY FOR TABLE1 CHECK IMMEDIATE UNCHECKED;
 
命令只對數據通過約束檢查的表有效,如果執行還不能解除,有必要檢查數據的完整性,是否不符合約束條件,並試圖重新整理數據,再執行裝入操作.
 
另外,對load和import,字面上的區別是:裝入和導入,但仍未理解兩者之間的區別.
 
只是性能上load顯然優於import.(load 需要更多的權限)
 
 
例如:
1.導出數據: db2 export  to t_sys_class.ixf of ixf select * from ams.t_sys_class
2. 導入:
  db2 load from t_sys_class.ixf of ixf modified by identityignore insert into docsdb.t_sys_class

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved