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 脚本
-d: 数据库名称:这必须指定 -e: 抽取复制数据库所需要的 DDL 文件 LaTeX 排版:latex filename.tex 以获得 filename.dvi 示例: db2look -d DEPARTMENT -u walid -e -o db2look.sql -- 这将生成由用户 WALID 创建的所有表和联合对象的 DDL 语句 示例: db2look -d DEPARTMENT -z myscm1 -e -o db2look.sql -- 这将为模式名为 MYSCM1 的所有表生成 DDL 语句 示例: db2look -d DEPARTMENT -u walid -m -o db2look.sql -- 这将生成 UPDATE 语句以捕获关于用户 WALID 创建的表/昵称的统计信息 示例: db2look -d DEPARTMENT -u walid -e -wrapper W1 -o db2look.sql 示例: db2look -d DEPARTMENT -u walid -e -server S1 -o db2look.sql -- 这将生成由用户 WALID 创建的所有表的 DDL 语句 方法一 在控制中心的对象视图窗口中,选择所要导出表结构的数据表,按住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 需要更多的权限) |