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 须要更多的权限)
相关文章
相关标签/搜索