ASPNET连接SQL数据库的简单实例代码

在ASP.NET Core中连接SQL Server数据库需使用Microsoft.Data.SqlClient库并配置连接字符串,以下是完整实现步骤及最佳实践:

ASPNET连接SQL数据库的简单实例代码

环境准备

  1. 安装NuGet包:
    Install-Package Microsoft.Data.SqlClient
  2. 配置appsettings.json:
    {
    "ConnectionStrings": {
     "DefaultConnection": "Server=.;Database=MyDB;User Id=sa;Password=YourStrong@Password;TrustServerCertificate=true;"
    }
    }

核心连接代码

using Microsoft.Data.SqlClient;
using Microsoft.Extensions.Configuration;
// 在Startup.cs或Program.cs注入配置
var builder = WebApplication.CreateBuilder(args);
var connectionString = builder.Configuration.GetConnectionString("DefaultConnection");
// 数据库操作类
public class DatabaseService
{
    public void ExecuteQuery()
    {
        using (SqlConnection connection = new SqlConnection(connectionString))
        {
            try
            {
                connection.Open();
                // 执行参数化查询(防SQL注入)
                string sql = "SELECT  FROM Users WHERE Id = @UserId";
                using (SqlCommand command = new SqlCommand(sql, connection))
                {
                    command.Parameters.AddWithValue("@UserId", 1);
                    using (SqlDataReader reader = command.ExecuteReader())
                    {
                        while (reader.Read())
                        {
                            Console.WriteLine(reader["UserName"]);
                        }
                    }
                }
            }
            catch (SqlException ex)
            {
                // 记录错误到日志系统
                Console.WriteLine($"SQL Error: {ex.Number} - {ex.Message}");
            }
            finally 
            {
                // 连接池自动回收资源
            }
        }
    }
}

关键技术解析

  1. 连接池优化

    • 默认启用连接池(Max Pool Size=100)
    • 使用using语句确保连接及时释放
    • 避免在循环中创建新连接
  2. 安全实践

    ASPNET连接SQL数据库的简单实例代码

    • 连接字符串存储:
      // 生产环境使用Azure Key Vault
      builder.Configuration.AddAzureKeyVault();
    • 始终使用参数化查询
    • 启用加密连接:
      "Encrypt=true;TrustServerCertificate=false;"
  3. 异步操作(高性能场景)

    public async Task<List<User>> GetUsersAsync()
    {
     var users = new List<User>();
     using (var conn = new SqlConnection(connectionString))
     {
         await conn.OpenAsync();
         var command = new SqlCommand("SELECT  FROM Users", conn);
         using (var reader = await command.ExecuteReaderAsync())
         {
             while (await reader.ReadAsync())
             {
                 users.Add(new User {
                     Id = reader.GetInt32(0),
                     Name = reader.GetString(1)
                 });
             }
         }
     }
     return users;
    }

异常处理规范

catch (SqlException ex) when (ex.Number == 4060) // 数据库不可用
{
    // 触发故障转移机制
}
catch (SqlException ex) when (ex.Number == 18456) // 登录失败
{
    // 发送凭证错误警报
}
catch (TimeoutException)
{
    // 启动重试策略
}

企业级部署建议

  1. 连接字符串配置策略:

    // 环境区分配置
    var env = builder.Environment;
    var config = new ConfigurationBuilder()
     .AddJsonFile($"appsettings.{env.EnvironmentName}.json")
     .Build();
  2. 连接健康检查(Kubernetes就绪探针):

    ASPNET连接SQL数据库的简单实例代码

    builder.Services.AddHealthChecks()
     .AddSqlServer(configuration["ConnectionStrings:DefaultConnection"]);

性能监控
在Program.cs启用诊断:

// 记录SQL执行耗时
builder.Services.AddDbContext<AppDbContext>(options => 
    options.UseSqlServer(connectionString)
           .EnableSensitiveDataLogging()
           .LogTo(Console.WriteLine, LogLevel.Information));

深度思考:当连接池达到上限时,如何在不重启应用的情况下动态扩展?建议采用分片连接策略:根据业务模块创建独立连接池,例如将订单业务和用户业务的数据库连接分离配置,通过Application Name标识:

"ConnectionStrings": {
  "OrderDB": "Server=...;Application Name=OrderModule;",
  "UserDB": "Server=...;Application Name=UserModule;"
}

您在实际项目中遇到的数据库连接难题是什么? 欢迎分享具体场景,我们将从架构设计层面分析解决方案,对于高并发场景下的连接泄露问题,是否有更优的实时检测方案?

首发原创文章,作者:世雄 - 原生数据库架构专家,如若转载,请注明出处:https://idctop.com/article/19068.html

(0)
上一篇 2026年2月9日 09:14
下一篇 2026年2月9日 09:17

相关推荐

  • ASP.NET行注释的使用方法和技巧有哪些?| ASP.NET代码注释完全指南

    在ASP.NET开发中,行注释(使用双斜杠 )是用于在代码中添加解释性文本或临时禁用单行代码的核心机制,这些注释会被编译器完全忽略,仅服务于开发者阅读和理解代码的目的,其核心价值在于提升代码的可读性、可维护性,并辅助调试过程,行注释的语法基础与核心作用语法: 之后直到该行结束的所有文本都被视为注释,// 这是一……

    程序编程 2026年2月10日
    6330
  • 服务器ddos怎么解决?防御DDoS攻击的有效方法有哪些

    解决服务器DDoS攻击的核心在于构建“防御纵深”体系,即通过高防IP清洗、流量调度与服务器自身加固相结合的方式,将恶意流量拦截在网络边缘,确保源站安全稳定运行,面对日益复杂的网络攻击,单一的技术手段已无法奏效,必须采用分层治理策略,从网络层到应用层逐级过滤,才能彻底解决服务器DDoS怎么解决这一运维难题, 接入……

    2026年4月2日
    1100
  • aspre是什么电脑

    Aspre并非一个已知的电脑品牌或具体型号,根据广泛的行业信息和市场数据,目前没有主流或知名的电脑制造商以“Aspre”作为品牌名称推出产品,它可能是一个拼写误差(例如与“Aspire”“Asus”等品牌混淆)、某个非常小众的本地品牌、特定渠道的定制机型名称,或者是某个旧款或区域性型号的误称,核心可能性分析与排……

    2026年2月4日
    5400
  • 服务器CPU哪家的好?高性价比服务器CPU品牌推荐

    在探讨服务器cpu哪家的好这一议题时,核心结论十分明确:没有绝对的“最好”,只有最适合特定业务场景的最优解,当前市场格局呈现“双雄争霸”态势,英特尔至强系列凭借极致的单核性能与完善的生态稳守存量市场,而AMD EPYC(霄龙)处理器则以恐怖的多核性能与超高性价比成为增量市场的首选,对于追求极致稳定性与传统软件兼……

    2026年4月2日
    700
  • asp.net简介,这个强大的.NET框架究竟有何独特之处?

    ASP.NET是由微软开发的一个开源Web应用框架,用于构建动态网站、Web应用程序和Web服务,它作为.NET框架的一部分,允许开发者使用C#、VB.NET等语言,结合HTML、CSS、JavaScript和服务器端脚本,创建从简单网页到企业级复杂系统的各种应用,ASP.NET以其高性能、安全性和可扩展性著称……

    2026年2月3日
    6100
  • AIoT深圳工程是什么?深圳AIoT工程公司排名推荐

    深圳作为全球硬件硅谷与科技创新中心,其AIoT(人工智能物联网)工程建设已从单纯的技术堆叠迈向智能化、系统化的深度融合阶段,核心结论在于:成功的AIoT深圳工程并非简单的设备联网,而是基于“端-边-云-网-智”全栈技术架构的系统性重构,其关键在于解决异构协议互通、数据价值挖掘以及场景化落地痛点,从而实现从“万物……

    2026年3月11日
    4700
  • 服务器cpu内存多大4核?4核服务器配多少内存合适

    4核服务器CPU的最佳内存配置通常在8GB至32GB之间,具体数值取决于实际业务负载类型,对于大多数Web应用、轻量级数据库及开发测试环境,8GB至16GB内存是性价比最高的黄金搭配,既能保证系统流畅运行,又避免了资源浪费,若涉及高并发数据处理或中型数据库服务,则建议提升至32GB甚至更高,以防止内存瓶颈导致系……

    2026年3月31日
    1600
  • ASPXMLDom操作XML文件的关键方法及实现细节是什么?

    ASP(Active Server Pages)通过XMLDOM组件为服务器端XML处理提供了强大支持,核心对象MSXML2.DOMDocument(或Microsoft.XMLDOM)允许开发者在ASP中高效解析、创建、修改和保存XML文件,其核心方法如下:核心方法与功能解析Load / LoadXML 方法……

    2026年2月5日
    6110
  • AI智能拍照软件哪个好用,手机怎么拍出大片感?

    计算摄影技术的突破性进展,标志着影像行业正式迈入了算法主导的新时代,通过深度学习与计算机视觉的深度融合,现代影像处理系统已经超越了单纯的光学记录,转而成为能够理解场景语义、优化光影表现并自动生成高质量图像的智能平台,AI智能拍照软件的核心价值在于,它利用强大的算力打破了传统硬件的物理限制,通过算法弥补传感器尺寸……

    2026年2月19日
    16100
  • AIPL秒杀是什么意思,AIPL秒杀活动怎么参加

    在数字化营销的激烈竞争中,实现品效合一的关键在于精准把握消费者决策的每一个瞬间,核心结论是:构建高效的转化闭环,必须依托AIPL模型实现从认知到忠诚的全链路管理,而针对不同阶段用户实施精准的“秒杀”策略,则是引爆流量、提升ROI的最优解, 这不仅是流量的争夺,更是用户资产的深度运营, 深度解析AIPL模型:转化……

    2026年3月8日
    6000

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

评论列表(3条)

  • 山山731的头像
    山山731 2026年2月16日 00:36

    读了这篇文章,我深有感触。作者对中连接的理解非常深刻,论述也很有逻辑性。内容既有理论深度,又有实践指导意义,确实是一篇值得细细品味的好文章。希望作者能继续创作更多优秀的作品!

  • 甜粉5406的头像
    甜粉5406 2026年2月16日 02:23

    这篇文章的内容非常有价值,我从中学习到了很多新的知识和观点。作者的写作风格简洁明了,却又不失深度,让人读起来很舒服。特别是中连接部分,给了我很多新的思路。感谢分享这么好的内容!

  • brave806love的头像
    brave806love 2026年2月16日 04:06

    读了这篇文章,我深有感触。作者对中连接的理解非常深刻,论述也很有逻辑性。内容既有理论深度,又有实践指导意义,确实是一篇值得细细品味的好文章。希望作者能继续创作更多优秀的作品!