use*_*259 7 sql t-sql sql-server sqlcmd
我确定这些之前已被问到但是找不到明确说明如何创建批处理文件让我们称之为"更新数据库"这个批处理文件应该
执行位于不同文件夹中的sql脚本执行另外3个bat文件.
任何快速的例子如何做?从来没有做过感谢很多
我可以这样做吗?
:On Error exit
:r C:\myPath\MasterUpdateDatabase.bat
GO
SQLCMD -S (Local) -i C:\myPath\InsertUsername.sql
Run Code Online (Sandbox Code Playgroud)
我收到一个错误:
"GO"不被视为内部外部命令
感谢您的任何意见
看起来您正在尝试使用DOS命令创建批处理文件,该文件可以(a)执行其他批处理文件,或者(b)执行SQLCMD以运行sql或sql脚本.
以下是几个例子.我正在使用START带有/WAIT开关的DOS命令,它将使您的原始"主"批处理文件在一个窗口中运行,并在新窗口中执行后续文件或命令.该新窗口保持打开状态,直到脚本完成并退出.
其中一些ECHO可能不是必需的,但脚本现在会回复给你一点点.
@echo off
Run Code Online (Sandbox Code Playgroud)
因此,从您运行脚本的角度来看,这非常简单.如果你是script1.bat有断点,你可以将错误返回到主脚本并立即结束.我不清楚这是否是你需要主脚本做的.
echo Starting Database Update.
echo.
echo Excuting Script 1
echo.
start /wait C:\path\to\your\script1.bat
echo If there was a problem, break here.
Pause
echo Excuting Script 2
echo.
start /wait C:\path\to\your\script2.bat
echo If there was a problem, break here.
Pause
Run Code Online (Sandbox Code Playgroud)
这里使用相同的START/WAIT来运行SQLCMD,在这种情况下只返回查询的结果.这里要注意的一件事是-Q(大写)运行查询并退出.如果您使用-q(小写),它将运行查询并在SQLCMD中打开,等待另一个查询.
echo.
echo Running SQLCMD: "select top 100 * from sys.objects"
start /wait sqlcmd -S (local) -Q "select top 100 * from sys.objects"
Run Code Online (Sandbox Code Playgroud)
这就是你如何运行一个sql脚本,这就是-i表示,但我也没有像之前那样在START/WAIT中运行它.不是你必须这样做,但我想展示这两个例子.这也表明-b如果脚本返回错误,将结束批处理过程,如果您运行的多个脚本依赖于前者的成功,这将非常有用.
echo.
echo Running SQLCMD from an (-i)nput file:
sqlcmd -S (local) -i C:\path\to\your\script.sql -b
echo.
echo Update Complete.
pause
End
Run Code Online (Sandbox Code Playgroud)
所以,我假设您正在寻找使用SQLCMD的.bat或.cmd文件.我提供的示例非常基本,但希望它能让您走上正确的道路.
哦!请记住,CTRL + C会破坏正在处理的批处理脚本.
| 归档时间: |
|
| 查看次数: |
44995 次 |
| 最近记录: |