DB2数据库使用

页面导航:首页 > 数据库 > DB2 > DB2数据库使用

DB2数据库使用

来源: 作者: 时间:2016-01-23 11:15 【

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 #导出数据...
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.数据库备份
 
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
Tags:

文章评论

最 近 更 新
热 点 排 行
Js与CSS工具
代码转换工具

<