SQL Server执行安装python环境

安装注意事项

启用python脚本支持

sql 复制代码
sp_configure 'external scripts enabled', 1;
RECONFIGURE;

安装后接受 Python EULA协议

sql 复制代码
接受python授权
setup.exe /qs /ACTION=Install /FEATURES=SQL_INST_MR /INSTANCENAME=您的实例名 /IACCEPTROPENLICENSETERMS=1 /IACCEPTPYTHONLICENSETERMS=1

重启SQL服务器

查询python版本 3.7

sql 复制代码
EXEC sp_execute_external_script
@language = N'Python',
@script = N'
import sys
print(sys.version)
'

不用requests(需要安装,安装失败)调用URL

复制代码
EXEC sp_execute_external_script
@language = N'Python',
@script = N'
from urllib.request import urlopen, Request
from urllib.parse import urlencode
import pandas as pd

url = "http://localhost/index.html"
params = {"key1": "value1", "key2": "value2"}
full_url = f"{url}?{urlencode(params)}"

try:
    request = Request(full_url)
    with urlopen(request, timeout=10) as response:
        status_code = response.getcode()
        content = response.read().decode("utf-8")[:1000]
except Exception as e:
    status_code = 0
    content = str(e)

OutputDataSet = pd.DataFrame({
    "URL": [full_url],
    "Status": [status_code],
    "Content": [content]
})
'
WITH RESULT SETS ((URL varchar(1000), Status int, Content varchar(1000)));

结果如下

存储过程:

sql 复制代码
CREATE PROCEDURE usp_CheckWebsiteStatus
    @URL varchar(1000)
AS
BEGIN
    -- 创建临时表存储结果
    CREATE TABLE #TempResult (
        URL varchar(1000),
        Status int,
        Content varchar(1000)
    );
    
    -- 使用INSERT EXEC模式捕获结果
    INSERT INTO #TempResult
    EXEC sp_execute_external_script
    @language = N'Python',
    @script = N'
from urllib.request import urlopen, Request
from urllib.parse import urlencode
import pandas as pd

url = URL_param
try:
    request = Request(url)
    with urlopen(request, timeout=10) as response:
        status_code = response.getcode()
        content = response.read().decode("utf-8")[:1000]
except Exception as e:
    status_code = 0
    content = str(e)

OutputDataSet = pd.DataFrame({
    "URL": [url],
    "Status": [status_code],
    "Content": [content]
})
    ',
    @params = N'@URL_param varchar(1000)',
    @URL_param = @URL;
    
    -- 返回结果
    SELECT * FROM #TempResult;
    
    -- 根据状态码执行不同业务逻辑
    DECLARE @Status int;
    SELECT @Status = Status FROM #TempResult;
    
    IF @Status = 200
    BEGIN
        -- 确保日志表存在
        IF NOT EXISTS (SELECT * FROM sys.tables WHERE name = 'WebsiteStatusLog')
        BEGIN
            CREATE TABLE WebsiteStatusLog (
                LogID int IDENTITY(1,1) PRIMARY KEY,
                CheckTime datetime NOT NULL,
                URL varchar(1000) NOT NULL,
                Status int NOT NULL,
                Content varchar(1000) NULL
            );
        END
        
        -- 记录错误日志
        INSERT INTO WebsiteStatusLog(CheckTime, URL, Status, Content)
        SELECT GETDATE(), URL, Status, Content FROM #TempResult;
    END
    
    -- 清理临时表
    DROP TABLE #TempResult;
END;
GO

-- 使用存储过程
EXEC usp_CheckWebsiteStatus 'http://localhost/index.html';
相关推荐
hashiqimiya1 小时前
两个步骤,打包war,tomcat使用war包
java·服务器·前端
黄俊懿1 小时前
【深入理解SpringCloud微服务】Seata(AT模式)源码解析——开启全局事务
java·数据库·spring·spring cloud·微服务·架构·架构师
我命由我123452 小时前
python-dotenv - python-dotenv 快速上手
服务器·开发语言·数据库·后端·python·学习·学习方法
txzz88882 小时前
CentOS-Stream-10 系统安装之网络设置
linux·运维·服务器·网络·计算机网络·centos
qq_401700412 小时前
嵌入式Linux网口MAC地址修改
linux·运维·macos
qq_310658512 小时前
mediasoup源码走读(六)——NetEQ
服务器·c++·音视频
繁星蓝雨2 小时前
Qt优雅的组织项目结构三(使用CMakeLists进行模块化配置)——————附带详细示例代码
开发语言·数据库·qt
Xの哲學3 小时前
Linux DRM 架构深度解析
linux·服务器·算法·架构·边缘计算
秋刀鱼 ..3 小时前
第三届信息化教育与计算机技术国际学术会议(IECA 2026)
运维·人工智能·科技·机器学习·制造
Jerry.张蒙3 小时前
SAP业财一体化实现的“隐形桥梁”-价值串
大数据·数据库·人工智能·学习·区块链·aigc·运维开发