`

(转)DB2导出数据库表结构和数据

    博客分类:
  • DB2
 
阅读更多


DB2导出数据库表结构和数据
2008年09月09日 星期二 12:10

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 需要更多的权限)

资料引用:http://www.knowsky.com/399738.html

分享到:
评论

相关推荐

    DB2导出数据库表结构和数据.pdf

    DB2 导出数据库表结构和数据 DB2 是一个关系数据库管理系统,能够高效地存储、管理和检索大量数据。在实际应用中,我们经常需要导出数据库表结构和数据,今天我们将讨论如何使用 DB2 导出数据库表结构和数据。 ...

    DB2导出数据库表结构和数据.docx

    在文档"DB2导出数据库表结构和数据.docx"中,主要讲述了如何在DB2环境中导出数据库的表结构和数据,以及相关的数据库管理和操作命令。以下是对这些知识点的详细解释: 1. **导出数据库结构**: 使用`db2look`命令...

    DB2导出、导入表结构、表数据及数据库安装小结(Windows环境)

    导出数据库全库表结构 为了确保在不同环境中能够一致地复现数据库的结构,导出全库表结构是一项重要的任务。下面详细介绍如何在Windows环境下使用DB2命令行工具来完成这一操作。 **步骤1:** 进入DB2安装目录下的...

    DB2导出表结构、表数据小结

    DB2 是一个关系数据库管理系统,提供了多种方式来导出表结构和表数据。在本文中,我们将介绍如何使用 DB2 命令行工具来导出表结构和表数据。 一、DB2 命令行导出数据库全库表结构 使用 DB2 命令行工具,可以将...

    db2导出数据库

    DB2Look是一款强大的DB2实用工具,主要用于导出DB2数据库对象结构以及数据。其具体用法如下: - **db2look -d db_name -i user_name -w password -a -e -o d:\script.sql** - `-d db_name` 指定要导出的数据库名称...

    DB2数据库导入导出

    2. 使用`db2move &lt;dbname&gt; export`命令导出数据库数据,如遇警告,可添加`-aw`参数强制执行。 #### 四、导入操作 ##### 4.1 建立新数据库 1. 切换至db2inst1用户:`su – db2inst1`。 2. 创建新数据库:`db2 ...

    PowerDesigner从数据库中导出表结构

    ### PowerDesigner从数据库中导出表结构 ...通过上述步骤,用户可以顺利地使用PowerDesigner从现有的数据库中导出表结构,并进一步进行数据分析和模型优化等工作。这对于加快项目进度、减少开发成本具有重要意义。

    DB2数据结构及数据导出导入

    这样,你就成功完成了从一个DB2数据库到另一个DB2数据库的数据结构和数据迁移过程。 总的来说,DB2的数据导出导入涉及到对数据库结构的理解、命令行工具的熟练运用以及迁移后的验证步骤。正确执行这些操作,可以在...

    DB2和ORACLE数据库导出表结构空间和存储过程脚本。

    它可能调用了上述提到的DB2和Oracle的命令行工具,以导出表结构、存储过程和表空间信息。用户运行这个文件时,应该会生成相应的DDL和PL/SQL脚本文件。 3. **CODE**: 这可能包含具体的SQL脚本或存储过程代码,用于更...

    db2数据库导入导出

    #### 一、DB2数据库导出表结构与数据 在DB2数据库管理中,经常需要将表结构或者表中的数据进行导出以供备份或者迁移使用。以下是对DB2数据库导出表结构与数据的具体步骤及详细解释。 ##### 方法一:图形界面导出表...

    DB2数据库命令

    --导出数据库表结构 db2look -d &lt;数据库名&gt; -u &lt;用户&gt; -e -o &lt;脚本名称&gt;.sql --导出数据库的表结构,其中用户空间一般为db2admin/db2inst1 db2look -d &lt;数据库名&gt; -u &lt;用户&gt; -t &lt;表1&gt; &lt;表2&gt; -e -o &lt;脚本名称&gt;.sql --...

    DB2 的数据库的导入、导出

    `db2import` 用于从数据文件导入数据到表或数据库,而 `db2export` 则用于从数据库导出数据到文件。这些命令提供了更高级的灵活性,可以自定义格式、过滤数据、处理大对象等。 总的来说,DB2的数据库导入和导出是...

    DB2导出数据操作指南_图解

    ### DB2导出数据操作指南知识点详析 #### 一、连接远程数据库步骤解析 **1.1 使用配置助手** 连接远程计算机上的DB2数据库,首先需启动DB2客户端的“配置助手”。此功能位于软件界面的“工具”菜单下。 **1.2 ...

    DB2数据库表导入MYSQL

    - 确保导出时包含所有列名和数据类型,以便于在MySQL中创建相应的表结构。 2. **创建MySQL表结构**: - 在MySQL中,创建与DB2相同结构的表。考虑到两种数据库的数据类型可能不同,如DB2的DATE与MySQL的DATE,需要...

    db2数据导出工具

    DB2数据导出工具,通常被称为`db2export`,是一个命令行实用程序,用于将数据从DB2数据库表中导出到文件,以便于进一步的数据处理、分析或备份。它支持多种格式,如CSV、TSV等,可以灵活地满足不同场景的需求。 2....

    PowerDesigner从数据库中导出表结构.doc

    * 数据 Reverse Engineering:可以使用PowerDesigner从Oracle数据库中导出表结构,然后进行数据Reverse Engineering,以便更好地理解数据库结构和数据关系。 PowerDesigner从Oracle数据库中导出表结构需要遵循一定...

    db2look导出存储过程脚本

    为了更好地管理和维护数据库中的对象(如存储过程、触发器等),DB2 提供了一系列实用工具,其中 db2look 就是一款用于导出数据库对象定义(包括存储过程)的强大工具。 #### 一、DB2 SYSCAT.ROUTINES 目录选取 在...

Global site tag (gtag.js) - Google Analytics