db2如何导出建表语句,使用什么工具,toad可以吗?

求给出具体的步骤
2024-11-23 08:55:56
推荐回答(1个)
回答(1):

DB2有自己的导出DDL语句工具:db2look,详细语法如下:
db2look-d DBname [-e] [-u Creator] [-z Schema] [-t Tname1 Tname2] [-h] [-o Fname] [-a][-m] [-c] [-r] [-l] [-x] [-xd] [-f] [-td x] [-noview] [-i userID] [-w password][-wrapper WrapperName]
[-server ServerName] [-nofed]
db2look-d DBname [-u Creator] [-s] [-g] [-a] [-t Tname1 Tname2...TnameN] [-p] [-oFname] [-i userID] [-w password]
db2look[-h]
参数说明:
-d:数据库名:这必须指定
-e:抽取复制数据库所需要的 DDL 文件,此选项将生成包含 DDL 语句的脚本,可以对另一个数据库运行此脚本以便重新创建数据库对象,此选项可以和 -m 选项一起使用。
-u:创建程序标识:若 -u 和 -a 都未指定,则将使用 $USER,若指定了 -a 选项,则将忽略 -u 选项。
-z:模式名:如果同时指定了 -z 和 -a,则将忽略 -z,联合部分的模式名被忽略。
-t:生成指定表的统计信息 可以指定的表的数目最多为 30。
-h:更详细的帮助消息
-o:将输出重定向到给定的文件名,若未指定 -o 选项,则输出将转到 stdout。
-a:为所有创建程序生成统计信息,若指定了此选项,则将忽略 -u 选项。
-m:在模拟方式下运行db2look,将生成包含SQL UPDATE语句的脚本,这些SQL UPDATE语句捕获所有统计信息,可以对另一个数据库运行此脚本以便复制初始的那一个,当指定了-m 选项时,将忽略 -p、-g 和 -s 选项。
-c:不要生成模拟的 COMMIT 语句,除非指定了 -m 或 -e,否则将忽略此选项,将不生成 CONNECT 和 CONNECT RESET 语句。
-r:不要生成模拟的 RUNSTATS 语句,缺省值为 RUNSTATS。仅当指定了 -m 时,此选项才有效。
-l:生成数据库布局:数据库分区组、缓冲池和表空间。
-x:如果指定了此选项,则 db2look 实用程序将生成授权 DDL,对于现有已授权特权,不包括对象的原始定义器。
-xd:如果指定了此选项,则 db2look 实用程序将生成授权 DDL,对于现有已授权特权,包括对象的原始定义器。
-f:抽取配置参数和环境变量,如果指定此选项,将忽略 -wrapper 和 -server 选项。
-td:将 x指定为语句定界符(缺省定界符为分号(;)),应该与 -e 选项一起使用(如果触发器或者 SQL 例程存在的话)。
-p:使用简单文本格式。
-s:生成postscript文件,此选项将为您生成postscript文件,当设置了此选项时,将除去所有latex和tmp ps文件,所需的(非IBM)软件:LaTeX和dvips,注意:文件psfig.tex必须在 LaTeX 输入路径中。
-g:使用图形来显示索引的页取装对,必须安装 Gnuplot,并且 必须在您的 LaTeX 输入路径中,还将随 LaTeX 文件一起生成 文件。
-i:登录到数据库驻留的服务器时所使用的用户标识
-w:登录到数据库驻留的服务器时所使用的密码
-noview:不要生成 CREATE VIEW ddl 语句
-wrapper:为适用于此包装器的联合对象生成 DDL,生成的对象可能包含下列各项:包装器、服务器、用户映射、别名、类型映射、函数模板、函数映射和索引规范
-server:为适用于此服务器的联合对象生成 DDL,生成的对象可能包含下列各项:包装器、服务器、用户映射、别名、类型映射、函数模板、函数映射和索引规范
-nofed:不要生成 Federated DDL,如果指定此选项,将忽略 -wrapper 和 -server 选项
LaTeX排字:latex filename.tex 以获得 filename.dvi
示例:
1、db2look -d DEPARTMENT -u walid -e -o db2look.sql    生成由用户 WALID 创建的所有表和联合对象的 DDL 语句, 输出到db2look.sql文件中。
2、db2look -d DEPARTMENT -z SCHEM -e -o db2look.sql   生成模式名为 SCHEM 的所有表生成 DDL 语句,还将生成 $USER 创建的所有联合对象的 DDL,输出到db2look.sql文件中。
3、db2look -d DEPARTMENT -u walid -m -o db2look.sql 生成 UPDATE 语句以捕获关于用户 WALID 创建的表/别名的统计信息,输出到db2look.sql文件中。
4、db2look -d DEPARTMENT -u walid -e -wrapper W1 -o db2look.sql 生成由用户 WALID 创建的所有表的 DDL 语句,还将生成适用于包装器 W1 的用户WALID所创建所有联合对象的DDL,输出到db2look.sql文件中。
5、db2look -d DEPARTMENT -u walid -e-server S1 -o db2look.sql 生成由用户 WALID 创建的所有表的 DDL 语句,还将生成适用于服务器 S1 的用户WALID所创建所有联合对象的DDL,输出到db2look.sql文件中。