场景: dba那边给我导出了所有的存储、函数等等对象的创建脚本,有上千个文件. 现在需要将这些对象创建脚本导入到另外一个库,如何解决呢? 手动一个个执行显然不太现实. 于是手动写了一个批处理,将所有的文件形成一个.sql的脚本,最后以@生成的.sql脚本方式导入
场景:
dba那边给我导出了所有的存储、函数等等对象的创建脚本,有上千个文件.
现在需要将这些对象创建脚本导入到另外一个库,如何解决呢?
手动一个个执行显然不太现实.
于是手动写了一个批处理,将所有的文件形成一个.sql的脚本,最后以@生成的.sql脚本方式导入到目标库中.
os环境:windows xp
脚本内容如下:
@echo offif exist list.sql del list.sql /q:inputclsset input=:set /p input= 请输入要进行判断的路径:set input=%input:=%:: 上面这句为判断%input%中是否存在引号,,有则剔除。if %input%==: goto inputif not exist %input% goto inputfor /f delims= %%i in ('dir /b /a-d /s %input%') do echo @@%%~fnxi>>list.sqlif not exist list.sql goto no_filestart list.sqlexit:no_fileclsecho%cur_dir% 出现错误,未成功生成list.sql脚本!pause
使用:
另存为.bat类型文件后,双击执行.
输入你脚本的路径:
如我的e盘cry文件夹下,有如下类型的文件:
test.prc
...
123test1.fnc(有子文件夹123)
...
test2.vw
..
执行该批处理后,最后生成的list.sql脚本文件内容如下(执行完批处理后会用默认的编辑器自动打开该文件):
@@e:crytest.prc
...
@@e:cry123test1.fnc
...
@@e:crytest2.vw
...
打开sqlplus,以指定用户登录数据库,然后执行: (我的脚本文件生成在d盘)
@d:list.sql
这样所有的对象就会自动在指定用户下生成.
---------------------------
注意:这样生成的对象很多都是无效的,因为没有按顺序生成,所以建议在自动执行完后,再编译一下所有无效的对象.
