加载中…
个人资料
  • 博客等级:
  • 博客积分:
  • 博客访问:
  • 关注人气:
  • 获赠金笔:0支
  • 赠出金笔:0支
  • 荣誉徽章:
正文 字体大小:

DB2批量执行SQL脚本的实现

(2010-12-22 01:34:34)
标签:

杂谈

分类: DB2

使用过的命令:

进入db2cmd

db2 connect to db_alias user username using password

db2 -tvf c:\abc.sql -l abc.log


参考如下:

 

可以在命令编辑器或者Windows 的DB2 命令窗口或者 Linux 的shell 中执行SQL 脚本。在windows 的DB2 命令窗口或者 linux 的shell 中执行SQL语句,可以使用下面的命令执行script1.sql脚本: 
      db2 -t -v -f script1.sql -z script1.log 
或者: 
       db2 –tvf script1.sql –z script1.log 
  在上面的命令中,

  -t 表示语句使用默认的语句终结符——分号;
  -v 表示使用冗长模式,这样 DB2 会显示每一条正在执行命令的信息;
  -f 表示其后就是脚本文件;
  -z 表示其后的信息记录文件用于记录屏幕的输出,方便以后的分析(这是可选的,但我们建议使用该选项)。

  当使用了-t选项而没有标明语句终结符,则分号(;)会默认为语句的终结符。有时可能会出现使用另外的终结符的情况,例如用SQL PL 编写的的脚本使用其它的符号而不是默认的分号,因为分号在SQL PL 是用于定义数据库对象过程中的语句结束。


 

下面为您介绍的是DB2批量执行SQL脚本的实现方法,如果您在DB2批量执行方面遇到过类似的问题的话,不妨一看,相信对您学习DB2批量执行方面会有所帮助。

环境:

Windows系统

DB2客户端或者服务端

一、准备工作

运行db2cmd或者db2cw打开DB2命令行处理器

进入SQL脚本存放目录

用db2 connect to <dbname> user <username> using <password> 命令连接数据库

用db2 set current schema <schema_name> 设置当前的SCHEMA,这个SCHEMA可以是未创建的,DB2会自动创建。

二、执行不同类型的SQL

1、在命令行执行简单SQL命令

db2 <SQL语句内容>

2、在命令行执行SQL脚本文件

db2 -td; -cf <SQL脚本文件路径> -l <输出日志文件路径>

说明:-td; 指定语句结束标志。因为一般SQL都是以分号结尾,所以就写成“-td;”。

-l <输出日志文件路径> 是可选的。

3、在命令行执行DB2 存储过程文件

db2 -td@ -f <SQL过程文件路径> -l <输出日志文件路径>

说明:-td; 指定语句结束标志。因为一般SQL过程都是以@结尾,所以就写成“-td@”。

-l <输出日志文件路径> 是可选的

三、写批处理脚本

批处理脚本无非就是把命令写在一起,保存为bat文件,执行即可。

在写批处理之前,先回顾一下DB2命令选项:

C:"IBM"SQLLIB"BIN>db2 ? options

db2 [option ...] [db2-command | sql-statement |

[? [phrase | message | sqlstate | class-code]]]

option:-a、-c、-d、-e{c|s}、-finfile、-i、-lhistfile、-m、-n、-o、

-p、-q、-rreport、-s、-t、-td;、-v、-w、-x 和 -zoutputfile。


选项    描述                                      缺省设置

------ ---------------------------------------- ---------------

-a    显示 SQLCA                                OFF

-c    自动落实                                  ON

-d    检索并显示 XML 声明                       OFF

-e    显示 SQLCODE/SQLSTATE                     OFF

-f    读取输入文件                              OFF

-i    显示 XML 数据并带有缩进                   OFF

-l    将命令记录到历史记录文件中                OFF

-m    显示受影响的行数                          OFF

-n    除去换行字符                              OFF

-o    显示输出                                  ON

-p    显示 db2 交互式提示符                     ON

-q    保留空格和换行符                          OFF

-r    将输出报告保存到文件                      OFF

-s    在命令出错时停止执行                      OFF

-t    设置语句终止字符                          OFF

-v    回传当前命令                              OFF

-w    显示 FETCH/SELECT 警告消息                ON

-x    不打印列标题                              OFF

-z    将所有输出保存到输出文件                  OFF

注意:

使用 DB2OPTIONS 环境变量定制选项缺省值。

紧跟选项字母后的减号(-)使该选项关闭。

使用 UPDATE COMMAND OPTIONS 更改选项设置(以交互式或

文件输入方式)。

根据命令参数创建批处理文件xxx.bat:

rem     -- 连接数据库

db2 connect to <dbname> user <username> using <password>

rem     -- 设置SCHEMA

db2 set current schema <schema_name>

rem     -- 执行SQL脚本列表

db2 -td; -cf <SQL脚本文件路径> -l <输出日志文件路径>

rem     -- 执行SQL过程列表

db2 -td@ -f <SQL过程文件路径> -l <输出日志文件路径>

注意:<SQL过程文件路径>可以是绝对路径也可以是相对路径。

四、执行批处理

运行db2cmd或者db2cw打开DB2命令行处理器。

如果<SQL过程文件路径>和<SQL脚本文件路径>为绝对路径,则可以直接命令行执行 xxx

如果<SQL过程文件路径>和<SQL脚本文件路径>为相对路径,则需要进入适当的目录,一边能在此目录下找到批处理,然后执行 xxx

AIX:

db2 -tvf 文件名.sql

0

阅读 收藏 喜欢 打印举报/Report
  

新浪BLOG意见反馈留言板 欢迎批评指正

新浪简介 | About Sina | 广告服务 | 联系我们 | 招聘信息 | 网站律师 | SINA English | 产品答疑

新浪公司 版权所有