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等大厂都工作过。当下为退役状态,写此篇文章属个人爱好。本人开发期间收集了很多开发课程等资料,需要可联系我

相关推荐
cdbqss114 分钟前
VB.net编写的身份证类
前端·.net
钢铁男儿14 分钟前
C# 接口(什么是接口)
java·数据库·c#
ChaITSimpleLove16 分钟前
.NET9 实现字符串拼接(StringConcatenation)性能测试
.net·性能测试·字符串拼接·csharp·string 拼接·benchmarktest
__风__1 小时前
PostgreSQL kv(jsonb)存储
数据库·postgresql
Databend1 小时前
Databend 产品月报(2025年6月)
数据库
Little-Hu2 小时前
QML TextEdit组件
java·服务器·数据库
保持学习ing4 小时前
day1--项目搭建and内容管理模块
java·数据库·后端·docker·虚拟机
宇钶宇夕5 小时前
EPLAN 电气制图:建立自己的部件库,添加部件-加SQL Server安装教程(三)上
运维·服务器·数据库·程序人生·自动化
爱可生开源社区5 小时前
SQLShift 重磅更新:支持 SQL Server 存储过程转换至 GaussDB!
数据库
贾修行5 小时前
SQL Server 空间函数从入门到精通:原理、实战与多数据库性能对比
数据库·sqlserver