DB2 SQL脚本批量执行的实现过程
创始人
2024-07-17 06:01:13
0

DB2 SQL脚本批量执行是我们在使用DB2数据库时经常要用到的操作,那么DB2 SQL脚本批量执行应该如何实现呢?阅读下文,您就可以找到答案。

DB2 SQL脚本批量执行:

环境:
Windows系统
DB2客户端或者服务端

一、准备工作
运行db2cmd或者db2cw打开DB2命令行处理器
进入SQL脚本存放目录
用db2 connect to user using 命令连接数据库
用db2 set current schema 设置当前的SCHEMA,这个SCHEMA可以是未创建的,DB2会自动创建。

二、执行不同类型的SQL
1、在命令行执行简单SQL命令
db2

2、在命令行执行SQL脚本文件
db2 -td; -cf -l <输出日志文件路径>

说明:-td; 指定语句结束标志。因为一般SQL都是以分号结尾,所以就写成“-td;”。
-l <输出日志文件路径>  是可选的。

3、在命令行执行DB2 存储过程文件
db2 -td@ -f -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 user using

rem     -- 设置SCHEMA
db2 set current schema

rem     -- 执行SQL脚本列表
db2 -td; -cf -l <输出日志文件路径>

rem     -- 执行SQL过程列表
db2 -td@ -f -l <输出日志文件路径>

注意:可以是绝对路径也可以是相对路径。

四、执行批处理
运行db2cmd或者db2cw打开DB2命令行处理器。
如果为绝对路径,则可以直接命令行执行 xxx

如果为相对路径,则需要进入适当的目录,一边能在此目录下找到批处理,然后执行 xxx

 

 

【编辑推荐】

DB2在线导出的方法

DB2 Merge语句的用法

DB2流程控制子句一览

深入探讨DB2表连接原理

几种常用的DB2循环用法

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
着眼MAC地址,解救无法享受D... 在安装了DHCP服务器的局域网环境中,每一台工作站在上网之前,都要先从DHCP服务器那里享受到地址动...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...