DB2中导出数据库的所有DDL脚本

来源:互联网 发布:通讯软件有哪些 编辑:程序博客网 时间:2024/04/27 18:55


我们用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 的文件中

0 0
原创粉丝点击