自动生成批量执行SQL脚本的批处理

场景: DBA那边给我导出了所有的存储、函数等等对象的创建脚本,有上千个文件. 现在需要将这些对象创建脚本导入到另外一个库,如何解决呢? 手动一个个执行显然不太现实. 于是手动写了一个批处理,将所有的文件形成一个.SQL的脚本,最后以@生成的.SQL脚本方式导入到目标库中. OS环境:WINDOWS xp 脚本内容如下: @echo off
if exist list.sql del list. http://www.haokk111.info sql /q
:input
cls
set input=:
set /p input=  请输入要进行判断的路径:
set "input=%input:"=%"
:: 上面这句为判断%input%中是否存在引号,有则剔除。
if "%input%"==":" goto input
if not exist "%input%" goto input
for /f "delims=" %%i in ('dir /b /a-d /s "%input%"') do echo @@%%~fnxi>>list.sql
if not exist list.sql goto no_file
start list.sql
exit

:no_file
cls
echo       %cur_dir% 出现错误,未成功生成list.sql脚本!
pause  使用: 另存为.BAT类型文件后,双击执行. 输入你脚本的路径: 如我的E盘CRY文件夹下,有如下类型的文件: TEST.PRC ... 123\TEST1.FNC(有子文件夹123) ... TEST2.VW .. 执行该批处理后,最后生成的list.sql脚本文件内容如下(执行完批处理后会用默认的编辑器自动打开该文件): @@E:\cry\TEST.PRC ... @@E:\cry\123\TEST1.FNC ... @@E:\cry\TEST2.VW ...   打开SQLPLUS,以指定用户登录数据库,然后执行: (我的脚本文件生成在d盘) @D:\list.sql 这样所有的对象就会自动在指定用户下生成. --------------------------- 注意:这样生成的对象很多都是无效的,因为没有按顺序生成,所以建议在自动执行完后,再编译一下所有无效的对象.         http://www.haofapiao.com 

转载于:https://www.cnblogs.com/fpqqchao/archive/2013/04/16/3023328.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值