数据库

位置:IT落伍者 >> 数据库 >> 浏览文章

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


发布日期:2022年09月17日
 
sql server自动生成批量执行SQL脚本的批处理

场景:

DBA那边给我导出了所有的存储函数等等对象的创建脚本有上千个文件

现在需要将这些对象创建脚本导入到另外一个库如何解决呢?

手动一个个执行显然不太现实

于是手动写了一个批处理将所有的文件形成一个SQL的脚本最后以@生成的SQL脚本方式导入到目标库中

OS环境:WINDOWS xp

脚本内容如下:

@echo offif exist listsql del listsql /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 /ad /s "%input%") do echo @@%%~fnxi>>listsqlif not exist listsql goto no_filestart listsqlexit:no_fileclsecho %cur_dir% 出现错误未成功生成listsql脚本!pause

使用:

另存为BAT类型文件后双击执行

输入你脚本的路径:

如我的E盘CRY文件夹下有如下类型的文件:

TESTPRC

TESTFNC(有子文件夹)

TESTVW

执行该批处理后最后生成的listsql脚本文件内容如下(执行完批处理后会用默认的编辑器自动打开该文件):

@@E:cryTESTPRC

@@E:cryTESTFNC

@@E:cryTESTVW

打开SQLPLUS以指定用户登录数据库然后执行: (我的脚本文件生成在d盘)

@D:listsql

这样所有的对象就会自动在指定用户下生成

注意:这样生成的对象很多都是无效的因为没有按顺序生成所以建议在自动执行完后再编译一下所有无效的对象

上一篇:SQL Server 请求失败问题的解决方案

下一篇:SQL Server备份和灾难恢复