RSS
热门关键字:  数据挖掘  人工智能  数据仓库  搜索引擎  数据挖掘导论

DB2中的数据移动——装入

来源: 作者:unkonwn 时间:2004-12-16 点击:

 

  装入(Load) 数据挖掘研究院

  装入命令格式与导入类似,命令关键字是Load,但是后面的参数比导入命令多的多,详细用法可以自行参考DB2文档。

数据挖掘研究院

  装入与导入类似,都是将输入文件中的数据移入到目标表中,二者的不同点将在实例中逐步解释。 数据挖掘研究院

  在装入之前,目标表必须已经存在。

  装入的性能比导入高,原因在后面结合实例详细解释。 数据挖掘研究院

  装入操作不记录到日志中,所以不能使用日志文件进行前滚操作。 数据挖掘实验室

  装入分为4个阶段:
  1. 装入阶段
  在这个阶段发生两件事:数据存储在表中,收集索引键并排序。在装入时,DBA可以指定多长时间生成一致点。

数据挖掘实验室

  它是装入工具的检查点。如果装入在执行期间被打断,它可以从最后一个一致点处开始继续重新执行。

数据挖掘研究院

  2. 构建阶段
  在构建阶段,基于在装入阶段收集的索引键信息创建索引。如果在构建阶段发生错误,装入工具就重启,它将从构建阶段开始处重新开始构建。 数据挖掘研究院

  3. 在删除阶段,所有违反唯一或主键约束的行都被删除并拷贝到一个异常表(如果在语句中指定相应选项)中。当输入行被拒绝,消息文件中就生成消息。

  4. 索引拷贝阶段
  如果在装入操作期间为索引创建指定了系统临时表空间,并且选择了 READ ACCESS 选项,该索引数据将从系统临时表空间拷贝到原来的表空间。

数据挖掘实验室

  装入过程的所有四个阶段都是操作的一部分,只有在所有的四个阶段都完成之后,该装入操作才算完成。在每个阶段都将生成消息,一旦其中的某个阶段发生错误,这些消息可以帮助DBA分析并解决问题。

  导入操作每次插入一行数据时都要检查是否满足约束条件,并且记入日志文件中。 数据挖掘研究院

  下面我们看一些LOAD命令特有的功能,IMPORT命令也能做的就不再详细说了。 数据挖掘研究院

  例十二:从光标类型文件中进行装入
  定义一个cursor
  declare mycur cursor for select * from org
  创建一个新表,结构与cursor相容
  create table org2 like org
  从cursor中装入
  load from mycur of cursor insert into org2

数据挖掘研究院

  除了可以从cursor中装入,还可以从文件、管道、设备中进行装入。而导入命令只能从文件中导入。

  例十三:关于异常表
  由用户定义的异常表可以用于存储不遵循唯一约束和主码约束的行。如果装入的时候没有指定异常表,则违反唯一约束的行将被丢弃并且将不再有机会恢复或修改。 数据挖掘研究院

  用SAMPLE数据库中的STAFF表做实验
  1. 创建一个结构与STAFF表相同的表STAFF1
  CREATE TABLE STAFF1 LIKE STAFF 数据挖掘研究院

  2. 把STAFF表中的一部分数据插入到STAFF1中
  INSERT INTO STAFF1 SELECT * FROM STAFF WHERE ID<=160

  3. 再创建一个结构与STAFF1相同的表STAFFEXP,作为异常表
  CREATE TABLE STAFFEXP LIKE STAFF1 数据挖掘研究院

  4. 给该异常表添加一列,因为异常表和普通表相比,前面的结构都相同,就是最后多出一列或两列(列名任意),第一列是时间戳类型,记录异常记录插入的时间,第二列是大文本类型(至少为32K大小),保存导致该条记录被拒绝的特定约束信息。本例中只添加一个时间戳列。
  ALTER TABLE STAFFEXP ADD COLUMN TIME TIMESTAMP 数据挖掘研究院

  5. 为STAFF1表创建一个唯一索引
  CREATE UNIQUE INDEX IDXSTAFF ON STAFF1(ID) 数据挖掘研究院

  6. 先运行导出命令做出一个文本文件
  EXPORT TO D:STAFF.TXT OF DEL SELECT * FROM STAFF 数据挖掘研究院

  7. 然后运行装入命令把数据再装入到STAFF1表中
  LOAD FROM D:STAFF.TXT OF DEL INSERT INTO STAFF1 FOR EXCEPTION STAFFEXP

数据挖掘研究院

  由于表STAFF1中有唯一索引,所以会有一部分数据因为违反这个约束条件而不能插入到STAFF1表中,这些记录就会插入到异常表STAFFEXP中。

数据挖掘研究院

  注意一点,异常表必须自己先定义好,装入命令不能够自动生成异常表,如果找不到指定的异常表,就会报错。

数据挖掘研究院

1 2 3 下一页>> 数据挖掘研究院

最全面的笔记本导购资讯,给您全方位的笔记本导购平台
最新评论共有 0 位网友发表了评论
发表评论
评论内容:不能超过250字,需审核,请自觉遵守互联网相关政策法规。
匿名?