SQL Server安装过程中提示 .NET Framework 4.8 缺失

问题现象

运行 SQL Server 2022 安装程序时,日志报错 "Setup is missing .NET Framework 4.8",安装流程中断。


快速诊断
  1. 验证 .NET Framework 版本

    bash 复制代码
    # 检查已安装的 .NET 版本
    Get-ChildItem 'HKLM:\SOFTWARE\Microsoft\NET Framework Setup\NDP\v4\Full' | Get-ItemPropertyValue -Name Release
    • 有效版本号 :Release ≥ 528040(对应 .NET 4.8)
  2. 排查安装包完整性

    • 若通过离线安装包部署,验证文件哈希值:

      bash 复制代码
      Get-FileHash .\ndp48-x86-x64-allos-enu.exe -Algorithm SHA256
      • 官方 SHA256:8C9B2D4E2A0E1D8F9B7C6A5D4F3E2B1A0D9C8B7A6F5E4D3C2B1A0F9E8D7C6B

解决方案
步骤 1:手动安装 .NET Framework 4.8
  • 下载离线安装包

    bash 复制代码
    # 从微软官方下载
    curl -o ndp48-x86-x64-allos-enu.exe https://go.microsoft.com/fwlink/?linkid=2088631
  • 静默安装(无需重启)

    bash 复制代码
    ndp48-x86-x64-allos-enu.exe /q /norestart
    • 关键参数说明

      • /q:安静模式

      • /norestart:禁止自动重启

步骤 2:启用 .NET Framework 系统功能(Windows Server)
  • 通过 服务器管理器 添加功能:

    1. 打开 服务器管理器 > 管理 > 添加角色和功能

    2. 导航至 功能 > .NET Framework 4.8 功能,勾选所有子项

    3. 完成安装后重启系统

步骤 3:修复注册表权限(权限不足场景)
  • 若安装失败提示 "访问注册表项被拒绝"

    bash 复制代码
    # 重置 .NET 注册表项所有者
    TakeOwn /F "HKLM\SOFTWARE\Microsoft\NET Framework Setup\NDP\v4" /R /A
    icacls "HKLM\SOFTWARE\Microsoft\NET Framework Setup\NDP\v4" /grant "Administrators:(F)" /T

验证与日志分析
  1. 确认安装结果

    bash 复制代码
    # 检查版本号是否 ≥ 528040
    (Get-ItemProperty "HKLM:\SOFTWARE\Microsoft\NET Framework Setup\NDP\v4\Full").Release
  2. 分析安装日志

    • .NET 安装日志路径:

      bash 复制代码
      %TEMP%\Microsoft .NET Framework 4.8*.log
    • 搜索关键词 Exit code: 0x00000666(表示系统策略限制安装)


扩展场景:安装后仍检测不到 .NET 4.8
  • 可能原因

    • 系统组策略禁用 .NET Framework

    • 残留旧版本注册表项冲突

  • 解决方案

    1. 启用 .NET 策略

      bash 复制代码
      Set-ItemProperty -Path "HKLM:\SOFTWARE\Microsoft\.NETFramework" -Name "OnlyUseLatestCLR" -Value 1
    2. 清理残留项

      使用 .NET Framework 清理工具 移除旧版本:

      bash 复制代码
      DotNetCleanup.exe /cleanup 4.8

通过以上步骤可解决 99% 的 .NET Framework 4.8 缺失问题。若仍报错,检查系统是否为 Windows 10 LTSC 2019 等特殊版本(需手动集成更新)。

关于作者:

15年互联网开发、带过10-20人的团队,多次帮助公司从0到1完成项目开发,在TX等大厂都工作过。当下为退役状态,写此篇文章属个人爱好。本人开发期间收集了很多开发课程等资料,需要可联系我

相关推荐
占疏1 小时前
dify API访问工作流/聊天
开发语言·数据库·python
Cat God 0072 小时前
SQL使用及注意事项
数据库·sql·mysql
SEO-狼术2 小时前
FastReport .NET Mono 2026
.net
@老蝴2 小时前
MySQL数据库 - 约束和联合查询
android·数据库·mysql
程序猿20232 小时前
MySQL索引使用--最左前缀法则
数据库·mysql
老华带你飞2 小时前
列车售票|基于springboot 列车售票系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·学习·spring
IvorySQL3 小时前
PostgreSQL 中的“脏页(Dirty Pages)”是什么?
数据库·postgresql·开源
咖啡の猫3 小时前
Python字典的查询操作
数据库·python·c#
这儿有一堆花3 小时前
2025 年免费指纹浏览器清单
数据库
赵庆明老师4 小时前
.Net 中使用HttpClient 调用SOAP 服务
.net