自动生成批量执行SQL脚本的批处理实例演示
作者 佚名
来源 批处理
浏览
发布时间 2013-07-09
场景: DBA那边给我导出了所有的存储、函数等等对象的创建脚本,有上千个文件. 现在需要将这些对象创建脚本导入到另外一个库,如何解决呢? 手动一个个执行显然不太现实. 于是手动写了一个批处理,将所有的文件形成一个.SQL的脚本,最后以@生成的.SQL脚本方式导入到目标库中. OS环境:WINDOWS xp 脚本内容如下: 复制代码 代码如下: @echo off if exist list.sql del list.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.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢! |
你可能对下面的文章感兴趣
关于自动生成批量执行SQL脚本的批处理实例演示的所有评论