1

我正在尝试使用 SQL 机器学习服务和 Python 做一些有用的事情。

我正在尝试将外部 python 脚本包含到 SQL 代码中。现在,我正在 SQL Server 2019 Dev Edition 上的 SQL Server Management Studio 上进行测试。

跟随Niels Berglund,我正在做的优秀文章:

EXEC sp_execute_external_script
@language =N'Python', 
@script=N'
import os
os.system("C:\TEMP\ml.py")
OutputDataSet = InputDataSet
print("Say Hello from SQL Server Management Studio")
',
@input_data_1 =N'SELECT 42' 
WITH RESULT SETS (([TheAnswer] int not null));  
GO 

我的ml.py脚本是这样的:

#!"C:\Program Files\Microsoft SQL Server\MSSQL15.MSSQLSERVER\PYTHON_SERVICES\python.exe"
print("Say Hello from the external script")

当我运行我的 T-SQL 脚本时,我得到了这个:

STDERR message(s) from external script: 
Access Denied

STDOUT message(s) from external script: 
Say Hello from SQL Management Studio


(1 row affected)

Completion time: 2020-12-23T08:51:59.9264251-05:00

我确保脚本具有我认为正确的权限:

在此处输入图像描述

我什至尝试将完全控制权分配给所有人。我在 SQL 或 Windows 事件查看器上都没有看到任何错误。

我尝试了以下变体os.system()但没有任何成功:

os.system("\"C:\Program Files\Microsoft SQL Server\MSSQL15.MSSQLSERVER\PYTHON_SERVICES\Lib\cust\ml.py\"")
os.system("\"C:\Program Files\Microsoft SQL Server\MSSQL15.MSSQLSERVER\PYTHON_SERVICES\python.exe\" \"C:\Program Files\Microsoft SQL Server\MSSQL15.MSSQLSERVER\PYTHON_SERVICES\Lib\cust\ml.py\"")
os.system("python.exe \"C:\Program Files\Microsoft SQL Server\MSSQL15.MSSQLSERVER\PYTHON_SERVICES\Lib\cust\ml.py\"")
os.system("python.exe C:\TEMP\ml.py")

任何想法都非常受欢迎。

谢谢!

4

1 回答 1

0

我终于能够通过以下方式完成这项工作:

  • 将python /script location/传递给os.system.
  • 将脚本放在cust我的 SQL Server 实例中 python 服务内的文件夹中。我对此并不太高兴。这似乎是文件夹权限的问题,但我试图在另一个更方便的文件夹上模仿它们,但我无法让它成功运行。

这是它的外观:

EXEC sp_execute_external_script
@language =N'Python', 
@script=N'
import os
os.system("python \"C:\Program Files\Microsoft SQL Server\MSSQL15.MSSQLSERVER\PYTHON_SERVICES\Lib\cust\ml.py\"")

OutputDataSet = InputDataSet
print("Say Hello from SQL Server Management Studio")
',
@input_data_1 =N'SELECT 42' 
WITH RESULT SETS (([TheAnswer] int not null));  
GO 
于 2020-12-28T18:07:15.247 回答