我正在尝试使用 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")
任何想法都非常受欢迎。
谢谢!