Windows环境下批量执行Oracle的SQL的一种方法

本文介绍了一种在Windows环境下使用批处理(batch)文件配合sqlplus工具批量执行SQL脚本的方法。通过设置环境变量如ORACLE_HOME, TNS_ADMIN等,并指定tnsnames.ora配置文件的位置,可以在客户端轻松地针对不同服务端数据库执行一系列SQL文件。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近在公司学到了一个实用的技术。客户端(执行本batch脚本的系统)是windows而服务端操作系统不限,客户端需要配置好ORACLE_HOME,
TNS_ADMIN以及tnsnames.ora。思路是利用batch和sqlplus批量执行SQL。使用方法:把所有的 xxx.sql
放在和本脚本同目录下然后运行batch即可。

脚本完整内容

@echo off
rem 这里的等于号两边不能留空格,变量值的双引号可以删除。
set UNM="OPF2MONITOR2"
set PWD="ORACLE"
set HOST="192.168.33.61:1521"
rem 以下为实例名
set SID="orcl"
rem 以下为tnsnames.ora中配置的数据库实例的别名
set SID_ALIAS="orcl_61"
rem 迭代执行与本脚本同目录下的每一个SQL文件
for /r ./ %%f in (*.sql) do echo %%h
    rem %%~f 删除任何引号
    ECHO %%~f
    rem 以下两种sqlplus命令格式任选其一
    rem sqlplus %USER%/%PWD%@%SID_ALIAS% @%%~f
    sqlplus %USER%/%PWD%@//%HOST%/%SID% @%%~f
)
pause

下载地址

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值