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如何实现二进制数据到文件的转换操作?详解二进制转文件技巧!

    在ASP中,二进制转文件指的是将服务器端接收或存储的二进制数据流(如文件上传内容或数据库BLOB字段)转换为物理文件的过程,常用于实现文件上传、下载或数据处理功能,核心方法是利用ASP内置对象如Request.BinaryRead读取二进制数据,再结合ADODB.Stream对象写入文件系统,确保高效、安全地保……

    2026年2月4日
    200
  • AI能源顾问怎么选优惠多?智能能源促销限时福利

    企业能源成本持续攀升,传统管理手段捉襟见肘?AI能源顾问正是您打破能耗困局、实现智能降本增效的核心利器, 它并非简单工具,而是融合尖端人工智能算法、深度行业洞察与实时物联数据的智慧中枢,精准切入能耗黑箱,驱动能源管理从粗放走向精益,从被动响应迈向主动优化,限时开放的专业版服务体验与专属优惠通道,正是您零风险启动……

    2026年2月14日
    100
  • ASP.NET新闻列表样式如何实现?分享高效开发技巧与代码优化方案

    <div class="news-container"> <div class="news-item"> <h2><a href="/news/aspnet-core-6-release" title=&quo……

    程序编程 2026年2月12日
    130
  • ASP.NET全局变量如何设置最有效?应用程序状态与Session应用实例

    在 ASP.NET 中,没有传统编程语言意义上的、贯穿整个应用程序生命周期且所有用户共享的单一全局变量,这是因为 Web 应用程序本质上是无状态的、多用户并发的,ASP.NET 提供了一系列状态管理机制来模拟不同范围和生命周期的“全局”数据存储,以满足不同场景的需求,理解这些机制及其适用场景是构建健壮 Web……

    2026年2月11日
    200
  • 如何实现Asp.Net环境下音频文件上传与在线播放的详细代码教程?

    在ASP.NET中实现音频文件上传与播放功能,可以通过结合前端交互与后端处理来完成,核心涉及文件上传的安全控制、存储管理以及音频播放的前端集成,以下将分步骤详细说明实现方案,音频文件上传的后端实现在ASP.NET Core中,处理文件上传通常使用IFormFile接口,确保后端API能够安全接收并保存音频文件……

    2026年2月3日
    150
  • ASP在网页开发中究竟有哪些独特优势,使其成为众多开发者的首选?

    ASP(Active Server Pages)作为微软推出的服务器端脚本环境,在构建动态网站方面具有显著优势,其核心价值在于能够高效整合HTML、脚本命令和COM组件,快速生成交互式网页,尤其适合Windows服务器环境下的企业级应用开发,以下从技术特性、开发效率、成本控制及生态兼容性角度展开分析,技术架构优……

    2026年2月3日
    300
  • asp三种控件究竟有何特点与区别?深度解析与比较!

    ASP(Active Server Pages)作为经典的服务器端脚本环境,在构建动态网站时依赖多种控件实现高效开发,三种核心控件——内置对象、ActiveX 组件及用户自定义控件,构成了ASP功能体系的基石,这些控件不仅简化了开发流程,还提升了代码的可维护性与执行效率,是ASP技术中不可或缺的工具,内置对象……

    2026年2月4日
    300
  • 如何在ASP.NET自定义控件中成功注册并使用JavaScript代码?

    在ASP.NET自定义控件开发中,JavaScript的注册与集成直接影响控件的交互性和复用性,常见问题包括脚本重复加载、依赖管理混乱、资源路径错误以及跨页面生命周期执行异常,以下是经过验证的专业解决方案:核心脚本注册机制解析ASP.NET提供两类脚本管理对象:ClientScriptManager(传统方案……

    2026年2月6日
    100
  • aspx环境包究竟有何独特之处?它对开发有何影响?揭秘其核心优势与使用疑问!

    ASPX环境包ASPX环境包是指为部署和运行基于ASP.NET框架(特别是使用.aspx页面的Web Forms应用程序)所必需的一套基础软件组件、运行库及配置集合,它并非一个单一的官方安装包,而是涵盖了从Web服务器、.NET运行时到数据库连接支持等一系列关键元素,确保ASP.NET应用程序能在目标服务器上正……

    2026年2月5日
    230
  • ASP中如何高效运用JavaScript实现动态交互功能?

    在ASP(Active Server Pages)动态网页开发中,有效整合JavaScript(JS)是构建现代、交互式、高性能Web应用的关键,ASP负责服务端逻辑、数据存取和动态内容生成,而JavaScript则赋能客户端,实现丰富的用户交互、动态内容更新和异步通信,两者的协同工作并非简单堆叠,而是需要清晰……

    2026年2月5日
    200

发表回复

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

评论列表(3条)

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

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

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

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

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

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