使用子进程执行 SQLCMD python

Execute SQLCMD using subprocess python

我想从 .dat 文件恢复 MS SQL 数据库。

我通过在 Windows PowerShell 上调用以下 command/statement 或将其保存在 .bat 文件中并 运行ning 文件本身成功地做到了这一点:

sqlcmd -S POLIVEIRA-PC\MSSQLSERVER2008 -Q "RESTORE DATABASE [Odemira_2012-07-01_021501] FROM DISK=N'C:\Program Files\Microsoft SQL Server\MSSQL10_50.MSSQLSERVER2008\MSSQL\Backup\ODEMIRA2013\Odemira_2012-07-01_021501' WITH FILE=1, MOVE N'Odemira_Data' TO N'C:\Program Files\Microsoft SQL Server\MSSQL10_50.MSSQLSERVER2008\MSSQL\DATA\Odemira_2012-07-01_021501.MDF', MOVE N'Odemira_Log' TO N'C:\Program Files\Microsoft SQL Server\MSSQL10_50.MSSQLSERVER2008\MSSQL\DATA\Odemira_2012-07-01_021501_1.LDF', NOUNLOAD, STATS=10"

但是,由于我需要针对不同的数据库多次重复此指令,因此我想使用 Python 循环执行。我尝试使用 subprocess 模块来复制上述指令。未成功。

我的Python代码如下:

import subprocess

host = 'POLIVEIRA-PC\MSSQLSERVER2008'
mssql_dir = 'C:\Program Files\Microsoft SQL Server\MSSQL10_50.MSSQLSERVER2008\MSSQL\DATA\'
db_dir = 'C:\Program Files\Microsoft SQL Server\MSSQL10_50.MSSQLSERVER2008\MSSQL\Backup\ODEMIRA2013\'
db = 'Odemira_2012-07-01_021501'

statement = '"RESTORE DATABASE [' + db + '] FROM DISK=N\'' + db_dir + \
            db + '\' WITH FILE=1, MOVE N\'Odemira_Data\' TO N\'' + mssql_dir + \
            db + '.MDF\', MOVE N\'Odemira_Log\' TO N\'' + mssql_dir + \
            db + '_1.LDF\', NOUNLOAD, STATS=10"'

subprocess.call(["sqlcmd", "-S", host, "-Q", statement])

当我在 Windows PowerShell 上 运行 这个 python 脚本时,出现以下错误:

PS C:\Users\POliveira\Dropbox\Academia\IST\Dissertacao_de_Mestrado\SQL> python .\lib\temp.py
Sqlcmd: 'RESTORE DATABASE [Odemira_2012-07-01_021501] FROM DISK=N'C:\Program Files\Microsoft SQL Server\MSSQL10_50.MSSQLSERVER2008\MSSQL\Backup\ODEMIRA2013\Odemira_2012-07-01_021501' WITH FILE=1, MOVE N'Odemira_Data' TO N'C:\Program Files\Microsoft SQL Server\MSSQL10_50.MSSQLSERVER2008\MSSQL\DATA\Odemira_2012-07-01_021501.MDF', MOVE N'Odemira_Log' TO N'C:\Program Files\Microsoft SQL Server\MSSQL10_50.MSSQLSERVER2008\MSSQL\DATA\Odemira_2012-07-01_021501_1.LDF', NOUNLOAD, STATS=10\""': Unexpected argument. Enter '-?' for help.

我不知道我错过了什么。我试过用反斜杠转义双引号 ("RESTORE ... 10"),但也没用。

编辑:我确实尝试在 subprocess.call 上添加标志 shell=True,但我以同样的错误结束。

去掉语句两边的双引号,像这样:

statement = 'RESTORE DATABASE [' + db + '] FROM DISK=N\'' + db_dir + \
            db + '\' WITH FILE=1, MOVE N\'Odemira_Data\' TO N\'' + mssql_dir + \
            db + '.MDF\', MOVE N\'Odemira_Log\' TO N\'' + mssql_dir + \
            db + '_1.LDF\', NOUNLOAD, STATS=10'