On-Premise的SQL Server提供了维护计划来定期、定时的维护SQL Server。一般的做法是:定义SQL Server Agent Jobs,而后维护计划帮助我们定期、定时执行SQL Server Agent Jobs。遗憾的是,SQL Database并不提供维护计划以及SQL Server Agent功能。
然而,根据MSDN的说法,我们依然可以通过SQL Server提供的维护计划连接到SQL Database。(Microsoft Azure SQL Database does not support SQL Server Agent or jobs. You can, however, run SQL Server Agent on your on-premise SQL Server and connect to Microsoft Azure SQL Database. http://msdn.microsoft.com/library/azure/ee336245.aspx#sqlagent )。具体做法如下:
通过SQL Server Agent可以调用sqlcmd命令,然后我们可以指定执行sqlcmd命令的服务器。这样,我们就可以配置一个SQL Server Agent Job去调用sqlcmd来维护SQL Database。
配置SQL Server Agent Job的方式如下 (SSMS 2012):
1. 新建一个SQL Server Agent Job:
2. 配置Job Steps:
3. 新建一个Job Step,Step类型选择Operating system (CmdExec):
4. 配置sqlcmd。在这个例子中,我试图通过sqlcmd去删除我的SQL Database中,HolTestDB数据库下,名为People表中,ID大于13的数据。那么这个命令为:
sqlcmd -U xxxxx -P xxxxxx -S xxxxx -d HolTestDB -Q "delete from People where ID > 13"
请注意,上述例子中参数的意义如下:
-U : SQL Database的用户名
-P : 密码
-d: 数据库名称
-Q: sql语句
-S : 服务器DNS名称。您可以通过管理门户找到,如下图:
5. 测试sqlcmd是否有效 (注:这个步骤并不是必须的)。测试的目的,是为了验证我们配置的命令是否真的有效。然而,我并不想在测试的过程就把数据删掉,所以我将sqlcmd命令改成(delete换成select):
sqlcmd -U xxxxx -P xxxxxx -S xxxxx -d HolTestDB -Q "select * from People"
在命令行窗口,输入上面命令并得到下面的结果,说明该命令可以work:
6. 为Agent Job设置sqlcmd命令并保存:
7. 运行Agent Job:选中刚才创建的Job,点右键,选择Start Job at Step…
8. 运行成功:
9. 第5步的方式验证以下结果,发现ID大于13的成功被删除:
此外,我们也可以将您的SQL脚本放到.sql文件中,那么sqlcmd相应调整如下(之前的例子,通过-Q参数指定sql语句;下面的例子,通过-i参数执行sql脚本文件):
sqlcmd -U xxxx –P xxxx -S xxxxx -d HolTestDB -i "D:\MaintainSqlAzure.sql"
更多关于sqlcmd的用户,请参考:
How to: Connect to Azure SQL Database Using sqlcmd