Import和Load 都可以将数据导入到DB2服务器中,但是2者是有很大区别的。
Import 其实执行了SQL 的INSERT 操作。和INSERT 操作一样,Import 执行的时候会激活触发器,所有的约束会强制实现,而且会使用数据库的缓冲池。类似Oracle sql*loader工具的常规路径导入。
 
Load 工具可以更快的将数据文件导入到数据表中。Load 工具不会与DB2 数据引擎发生交互,所以当使用Load 工具时,不会触发触发器也不会使用缓冲池,而且必须单独实现数据表的约束。Import 工具执行起来比Load 慢是因为它是低层次的数据操作工具,它分
LOAD,BUILD,DELETE 三个阶段对硬盘上的数据页面来进行直接的处理。Load工具类似Oracle sql*loader工具的直接路径导入。
通过下面一个例子可以说明这一点:
db2 => connect @
   Database Connection Information
 Database server        = DB2/LINUX 9.7.0
 SQL authorization ID   = HUATENG
 Local database alias   = DBTEST
db2 => create table test(id int not null primary key,name varchar(20)) @
DB20000I  The SQL command completed successfully.
db2 => commit @
DB20000I  The SQL command completed successfully.
db2 => create trigger tri_test 
db2 (cont.) => no cascade
db2 (cont.) => before insert on test
db2 (cont.) => referencing new as n
db2 (cont.) => for each row
db2 (cont.) => begin atomic
db2 (cont.) =>    set n.name=n.name||' [import test]';
db2 (cont.) => end @
DB20000I  The SQL command completed successfully.
db2 => commit @
DB20000I  The SQL command completed successfully.
db2 => insert into test values(1,'a') @
DB20000I  The SQL command completed successfully.
db2 => commit @
DB20000I  The SQL command completed successfully.
db2 => select * from test @
ID          NAME                
----------- --------------------
          1 a [import test]    
  1 record(s) selected.
db2 => ! cat test.txt @
1,"aa"
2,"bb"
3,"cc"
4,"dd"
5,"ee"
6,"ff"
db2 => import from test.txt of del insert into test @
SQL3109N  The utility is beginning to load data from file "test.txt".
SQL3148W  A row from the input file was not inserted into the table.  SQLCODE "-803" was returned.
SQL0803N  One or more values in the INSERT statement, UPDATE statement, or foreign key update caused by a DELETE statement are not valid because the 
primary key, unique constraint or unique index identified by "1" constrains table "HUATENG.TEST" from having duplicate values for the index key.  
SQLSTATE=23505
SQL3185W  The previous error occurred while processing data from row "1" of the input file.
SQL3110N  The utility has completed processing.  "6" rows were read from the input file.
SQL3221W  ...Begin COMMIT WORK. Input Record Count = "6".
SQL3222W  ...COMMIT of any database changes was successful.
SQL3149N  "6" rows were processed from the input file.  "5" rows were successfully inserted into the table.  "1" rows were rejected.
Number of rows read         = 6
Number of rows skipped      = 0
Number of rows inserted     = 5
Number of rows updated      = 0
Number of rows rejected     = 1
Number of rows committed    = 6
db2 => select * from test @
ID          NAME                
----------- --------------------
          1 a [import test]     
          2 bb [import test]    
          3 cc [import test]    
          4 dd [import test]    
          5 ee [import test]    
          6 ff [import test]   
  6 record(s) selected.
可以看到文件中的记录1由于主键冲突而被拒绝导入,日志文件显示 Number of rows rejected     = 1 ,
其他导入的记录也都触发了触发器操作。
下面看看Load工具的情况:
db2 => delete from test where id>1 @
DB20000I  The SQL command completed successfully.
db2 => commit @
DB20000I  The SQL command completed successfully.
db2 => select * from test @
ID          NAME                
----------- --------------------
          1 a [import test]    
  1 record(s) selected.
首先删掉导入的记录,只保留ID=1的记录。
db2 => ! cat test.txt
db2 (cont.) => @
1,"aa"
2,"bb"
3,"cc"
4,"dd"
5,"ee"
6,"ff"
db2 => load from test.txt of del insert into test @
SQL3501W  The table space(s) in which the table resides will not be placed in backup pending state since forward recovery is disabled for the database.
SQL3109N  The utility is beginning to load data from file "/home/huateng/test.txt".
SQL3500W  The utility is beginning the "LOAD" phase at time "2012-03-29 06:41:44.784072".
SQL3519W  Begin Load Consistency Point. Input record count = "0".
SQL3520W  Load Consistency Point was successful.
SQL3110N  The utility has completed processing.  "6" rows were read from the input file.
SQL3519W  Begin Load Consistency Point. Input record count = "6".
SQL3520W  Load Consistency Point was successful.
SQL3515W  The utility has finished the "LOAD" phase at time "2012-03-29 06:41:44.808464".
SQL3500W  The utility is beginning the "BUILD" phase at time "2012-03-29 06:41:44.809206".
SQL3213I  The indexing mode is "REBUILD".
SQL3515W  The utility has finished the "BUILD" phase at time "2012-03-29 06:41:44.914248".
SQL3500W  The utility is beginning the "DELETE" phase at time "2012-03-29 06:41:44.952664".
SQL3509W  The utility has deleted "1" rows from the table.
SQL3515W  The utility has finished the "DELETE" phase at time "2012-03-29 06:41:44.979506".
Number of rows read         = 6
Number of rows skipped      = 0
Number of rows loaded       = 6
Number of rows rejected     = 0
Number of rows deleted      = 1
Number of rows committed    = 6
db2 => select * from test @
ID          NAME                
----------- --------------------
          1 a [import test]     
          2 bb                  
          3 cc                  
          4 dd                  
          5 ee                  
          6 ff                 
  6 record(s) selected.
很明显导入结果没有触发触发器操作,而且并没有拒绝任何行,相反的是有一条记录被删除了,这是因为Load会把所有的满足条件记录导入到表中,在 load的DELETE阶段将会删掉重复的记录行。

db2 import和load的更多相关文章

  1. db2 import export load

    DB2中所谓的数据移动,包括: 1. 数据的导入(Import) 2. 数据的导出(Export) 3. 数据的装入(Load) 导入和装入都是利用DB2的相关命令把某种格式的文件中的数据保存到数据库 ...

  2. win7 32位 安装opencv-python后,运行时提示 "from .cv2 import *: DLL load failed: 找不到指定的模块" 的解决办法

    安装opencv后,运行一个测试程序提示"from .cv2 import *: DLL load failed: 找不到指定的模块".于是百度一下解决办法,结果试了N多方法后也没 ...

  3. DB2 Z/os Load utility 使用

    Use the LOAD online utility to load one or more tables of a table space. The LOAD utility loads reco ...

  4. 【DB2】文件导入导出常见命令总结 EXPORT IMPORT LOAD

    参考文献地址:https://blog.csdn.net/reaper1022/article/details/18601973 Db2 的数据迁移,最常用的就是导入导出功能,而导入导出的命令貌似简单 ...

  5. db2 load选项

    db2 load使用 最近有个好朋友因为load问题导致了生产故障,所以特意写篇文章总结一下load的用法及注意事项. 1.load概述 数据的导入方法有insert,import和load三种,其中 ...

  6. 【DB2】db2命令Export与Import

    环境准备 1.新建表 qinys@Linux:~> db2 "create table tb1(id int,dt timestamp,name varchar(100))" ...

  7. [转]DB2 load参数

    本文持续更新,LOAD如何提高parallelism.LOAD SHRLEVEL CHANGE的性能提高. =========================== Every once in a wh ...

  8. db2基础

    DB2知识文档 一.db2 基础 基本语法 注释:"--"(两个减号) 字符串连接:"||" 如set msg='aaaa'||'bbbb',则msg为'aaa ...

  9. DB2 常用命令小结

    . 打开命令行窗口 #db2cmd . 打开控制中心 # db2cmd db2cc . 打开命令编辑器 db2cmd db2ce =====操作数据库命令===== . 启动数据库实例 #db2sta ...

随机推荐

  1. Android系统源代码——所需工具

    一.概述 众所周知,Android移动操作系统是Google花费了很大的财力.物力及人力的前提下,推广到世界各个角落,以开放源代码的方式(当然也不是完全开放所有),使其在世界范围内迅速漫延开来,到目前 ...

  2. android使用achartengine 实现折线图

    折线图的实现分为下边几个步骤: 1.第一步:数据的准备 XYMultipleSeriesDataset mDataset = new XYMultipleSeriesDataset(); XYSeri ...

  3. index.js

    <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding= ...

  4. PHP-根据字符串和所用字体计算字符串所占宽高

    今天由于用GD画图, 需要把一段文字在一个框内居中, 但是文字的宽度如果用strlen($str) * $font_size来计算的话, 由于文字不是等宽高的, 所以会导致偏离, 最后选用的GD库的i ...

  5. 随笔小问题(一)--mac打开class文件

    本来不想写这个东西的.但是这个却费了我一番周折. 我要先声明一点的是,我从来不讲iOS当成一个单独的系统,而是将这个操作系统归位unix内核的系统. 简单来说,我把它当成linux在用. 但是,mac ...

  6. 详解C#泛型(二) 获取C#中方法的执行时间及其代码注入 详解C#泛型(一) 详解C#委托和事件(二) 详解C#特性和反射(四) 记一次.net core调用SOAP接口遇到的问题 C# WebRequest.Create 锚点“#”字符问题 根据内容来产生一个二维码

    详解C#泛型(二)   一.自定义泛型方法(Generic Method),将类型参数用作参数列表或返回值的类型: void MyFunc<T>() //声明具有一个类型参数的泛型方法 { ...

  7. IE提示console未定义问题解决

    在页面加入如下代码: if (!window.console || !console.firebug){    var names = ["log", "debug&qu ...

  8. STM32出现HardFault故障的解决方法

    https://wenku.baidu.com/view/a4a7499afad6195f312ba6d2.html https://wenku.baidu.com/view/085b6fbe5022 ...

  9. 常用音频软件:Cool edit pro

    作者:桂. 时间:2017-06-02  11:51:08 链接:http://www.cnblogs.com/xingshansi/p/6932671.html 这里只涉及Cool edit pro ...

  10. fft分析前后频谱数据

    正弦信号输入 input 输入的原始信号 short [128] fir 滤波后的输出信号 SHORT [128] fft 傅里叶变换后的freq数据  float [128] rmroise 去除底 ...