aspnet如何连接数据库读取数据?详细步骤与示例分享

在ASP.NET Core中高效安全地连接数据库并读取数据是开发Web应用的核心能力,以下是基于ADO.NET的专业实现方案,遵循最佳实践确保性能与安全:

aspnet如何连接数据库读取数据?详细步骤与示例分享


环境准备与配置

  1. 引用必要NuGet包

    Install-Package System.Data.SqlClient # SQL Server
    # 或 Install-Package MySql.Data # MySQL
  2. 配置连接字符串 (appsettings.json)

    {
    "ConnectionStrings": {
     "DefaultConnection": "Server=.;Database=YourDB;User Id=sa;Password=YourPwd;Encrypt=True;TrustServerCertificate=True;"
    }
    }

分层架构实现(推荐)

数据访问层 (DAL)

public class ProductRepository
{
    private readonly IConfiguration _config;
    public ProductRepository(IConfiguration config) 
    {
        _config = config;
    }
    public List<Product> GetProducts()
    {
        var products = new List<Product>();
        // 使用using确保资源释放
        using (var conn = new SqlConnection(
            _config.GetConnectionString("DefaultConnection")))
        {
            // 参数化查询防SQL注入
            var sql = "SELECT ProductId, Name, Price FROM Products WHERE Stock > @MinStock";
            using (var cmd = new SqlCommand(sql, conn))
            {
                cmd.Parameters.AddWithValue("@MinStock", 10);
                conn.Open();
                using (var reader = cmd.ExecuteReader())
                {
                    while (reader.Read())
                    {
                        products.Add(new Product()
                        {
                            Id = reader.GetInt32(0),
                            Name = reader.GetString(1),
                            Price = reader.GetDecimal(2)
                        });
                    }
                }
            }
        }
        return products;
    }
}
public class Product
{
    public int Id { get; set; }
    public string Name { get; set; }
    public decimal Price { get; set; }
}

服务层调用 (Service Layer)

public class ProductService
{
    private readonly ProductRepository _repo;
    public ProductService(ProductRepository repo) 
    {
        _repo = repo;
    }
    public IEnumerable<Product> GetAvailableProducts() 
    {
        return _repo.GetProducts();
    }
}

控制器注入 (Controller)

aspnet如何连接数据库读取数据?详细步骤与示例分享

[ApiController]
[Route("api/[controller]")]
public class ProductsController : ControllerBase
{
    private readonly ProductService _service;
    public ProductsController(ProductService service) 
    {
        _service = service;
    }
    [HttpGet]
    public IActionResult Get() 
    {
        return Ok(_service.GetAvailableProducts());
    }
}

关键安全与性能优化

  1. 防御性编程

    • 参数化查询:彻底杜绝SQL注入
    • 连接池:默认启用,通过Pooling=true控制
    • 错误日志:捕获SqlException并记录
  2. 异步操作提升吞吐量

    public async Task<List<Product>> GetProductsAsync()
    {
     using (var conn = new SqlConnection(_config.GetConnectionString("DefaultConnection")))
     {
         await conn.OpenAsync();
         using (var cmd = new SqlCommand("SELECT...", conn))
         {
             using (var reader = await cmd.ExecuteReaderAsync())
             {
                 // 异步读取逻辑
             }
         }
     }
    }
  3. 企业级扩展方案

    • ORM选择:Entity Framework Core(复杂业务场景)
    • Dapper:高性能微ORM(适合读密集型操作)
    • 连接管理:使用IDbConnectionFactory

不同数据库适配方案

数据库类型 连接包 连接字符串示例
SQL Server System.Data.SqlClient Server=.;Database=DB;User=sa;Pwd=xxx;
MySQL MySql.Data Server=localhost;Database=DB;Uid=root;Pwd=xxx;
PostgreSQL Npgsql Host=localhost;Database=DB;Username=postgres;Password=xxx;

常见陷阱解决方案

  1. 连接泄露

    • 错误:未调用Dispose()
    • 修复:严格使用using
  2. 密码硬编码

    aspnet如何连接数据库读取数据?详细步骤与示例分享

    • 错误:代码中写死连接串
    • 修复:通过IConfiguration注入 + 使用Azure Key Vault
  3. 查询超时

    • 错误:复杂查询未设超时
    • 修复:cmd.CommandTimeout = 30;

架构师建议:在微服务场景下,建议将数据库访问封装为独立服务,通过gRPC或REST API提供数据,对于高并发读取,可引入Redis缓存查询结果,响应速度可提升10倍以上。


互动讨论:你在实际项目中如何处理分库分表的数据读取?是否遇到过连接池耗尽的情况?欢迎在评论区分享你的实战经验与解决方案!

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

(0)
上一篇 2026年2月9日 07:31
下一篇 2026年2月9日 07:34

相关推荐

  • ColoCrossing美国VPS测评,12美元/年实测数据与性能表现,ColoCrossing美国VPS好用吗

    ColoCrossing美国VPS以12美元/年的极致性价比,在低预算建站与轻量级开发场景中具备显著优势,但其共享资源特性决定了它不适合高并发或重度计算需求,适合追求极致低成本的个人开发者及小型博客用户,ColoCrossing美国VPS基础配置与价格解析在2026年的VPS市场中,ColoCrossing依然……

    2026年5月13日
    1900
  • AI加速引擎是什么,如何提升AI模型推理速度?

    ai加速引擎作为智能时代的核心动力,通过软硬协同设计解决了算力瓶颈,实现了高性能与低功耗的平衡,是推动大模型落地与AI普惠的关键基础设施,其核心价值在于将海量的数据吞吐与矩阵运算效率最大化,从而降低企业智能化转型的边际成本,在数字化转型的深水区,算力已成为新的生产力,传统的通用处理器(CPU)已无法满足深度学习……

    2026年2月23日
    9900
  • AIoT趋势启动了吗?AIoT未来发展趋势分析

    AIoT趋势启动标志着人工智能与物联网技术从单点突破迈向深度融合的新阶段,其核心驱动力在于“数据智能”与“万物互联”的化学反应,正在重塑产业格局并创造万亿级市场价值,这一趋势并非简单的技术叠加,而是通过AI赋予IoT设备“大脑”,使其具备感知、分析、决策能力,从而实现从“连接”到“赋能”的质变,核心结论:AIo……

    2026年3月10日
    8300
  • AI智能电视算法是什么,如何关闭个性化推荐?

    AI智能电视算法是现代显示技术的核心引擎,它彻底改变了传统电视仅作为被动显示终端的属性,核心结论在于,通过深度学习与计算机视觉技术,这套算法体系解决了画质提升、内容检索与交互效率三大痛点,实现了从“看得到”到“看得好、找得快、用得爽”的体验质变,它不仅是对硬件算力的调度,更是对用户视觉感知与内容需求的深度理解与……

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

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

    2026年2月11日
    10000
  • 服务器iis怎么备份?IIS备份还原详细步骤教程

    备份IIS配置不仅是数据安全的最后一道防线,更是服务器运维中不可或缺的“后悔药”,针对服务器iis怎么备份这一核心问题,最专业且高效的解决方案是:采用IIS管理器内置的“配置备份”功能结合手动文件复制,构建“配置+内容”的双重备份体系,并利用Windows任务计划程序实现自动化运维,确保在服务器崩溃或误操作时能……

    2026年4月5日
    5100
  • C和ASP.NET学哪个好?2026开发者首选技术路线解析

    C#是微软推出的现代化、类型安全的面向对象编程语言,运行于高性能的.NET平台上,广泛应用于企业级系统、云服务、游戏开发(Unity引擎)、移动应用(Xamarin)及物联网解决方案,其核心价值在于平衡开发效率与执行性能,通过持续创新保持技术领先性,C#的核心技术优势解析强类型系统与内存安全// 编译时类型检查……

    2026年2月12日
    10500
  • 服务器IP地址如何自动获取?服务器IP自动分配方法

    服务器IP地址自动获取是现代网络基础设施高效运维的核心能力之一,尤其在动态部署、云原生架构和大规模集群环境中,自动化IP分配机制显著降低人工配置错误率,提升资源响应速度达70%以上,本文将从技术原理、主流方案、实操步骤、风险规避及最佳实践五个维度,系统解析如何实现服务器IP地址自动获取,为运维团队提供可落地的决……

    2026年4月15日
    3000
  • AIoT的个人见解是什么,AIoT未来发展前景如何

    AIoT(人工智能物联网)的本质是人工智能与物联网的深度融合,其核心价值在于实现了从“万物互联”到“万物智联”的跨越,这一技术架构不仅重塑了物理世界与数字世界的边界,更通过智能化的决策机制,极大提升了社会生产效率与资源利用率, 简而言之,AIoT让冰冷的设备拥有了“大脑”,让数据的流动产生了真正的商业价值, 核……

    2026年3月14日
    11000
  • AIoT生态投资怎么样?AIoT生态投资前景如何

    AIoT生态投资的核心逻辑在于捕捉技术融合带来的价值重构机遇,其本质是投资于数据智能与物理世界的深度连接能力,未来的投资回报将不再局限于单一硬件销售,而是源于数据闭环产生的服务价值与生态协同效应,投资者应重点关注具备底层技术壁垒、场景落地能力以及生态整合潜力的企业,而非单纯的硬件制造商, 技术融合重构价值链,投……

    2026年3月12日
    10100

发表回复

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