ASP.NET如何连接SQL数据库?完整访问教程步骤详解

在 ASP.NET 中访问数据库有多种方式,以下是几种主流方法和详细步骤(以 SQL Server 为例):

asp.net怎样访问数据库


ADO.NET(底层直接访问)

核心步骤:

  1. 添加命名空间

    using System.Data.SqlClient;  // .NET Framework
    // 或
    using Microsoft.Data.SqlClient; // .NET Core+ (推荐)
  2. 配置连接字符串

    • Web.config (ASP.NET) 或 appsettings.json (ASP.NET Core) 中添加:
      <!-- Web.config -->
      <connectionStrings>
        <add name="MyDb" 
             connectionString="Server=服务器地址;Database=数据库名;User Id=用户名;Password=密码;"
             providerName="System.Data.SqlClient"/>
      </connectionStrings>
      // appsettings.json (.NET Core)
      {
        "ConnectionStrings": {
          "MyDb": "Server=.;Database=MyDB;Integrated Security=True;"
        }
      }
  3. 执行数据库操作

    // 读取数据示例
    string connectionString = ConfigurationManager.ConnectionStrings["MyDb"].ConnectionString;
    // .NET Core: 通过依赖注入获取 IConfiguration,再取 connectionString
    using (SqlConnection conn = new SqlConnection(connectionString))
    {
        string sql = "SELECT * FROM Products";
        SqlCommand cmd = new SqlCommand(sql, conn);
        conn.Open();
        SqlDataReader reader = cmd.ExecuteReader();
        while (reader.Read())
        {
            string productName = reader["ProductName"].ToString();
            // 处理数据...
        }
    }

Entity Framework Core(推荐 ORM)

步骤:

  1. 安装 NuGet 包

    Install-Package Microsoft.EntityFrameworkCore.SqlServer
    Install-Package Microsoft.EntityFrameworkCore.Design
  2. 创建数据模型

    public class Product
    {
        public int Id { get; set; }
        public string Name { get; set; }
        public decimal Price { get; set; }
    }
  3. 创建 DbContext

    asp.net怎样访问数据库

    public class AppDbContext : DbContext
    {
        public AppDbContext(DbContextOptions<AppDbContext> options) : base(options) { }
        public DbSet<Product> Products { get; set; }
    }
  4. 配置依赖注入(Startup.cs)

    public void ConfigureServices(IServiceCollection services)
    {
        services.AddDbContext<AppDbContext>(options =>
            options.UseSqlServer(Configuration.GetConnectionString("MyDb")));
    }
  5. 在控制器中使用

    public class ProductController : Controller
    {
        private readonly AppDbContext _context;
        public ProductController(AppDbContext context)
        {
            _context = context; // 依赖注入
        }
        public IActionResult Index()
        {
            var products = _context.Products.ToList();
            return View(products);
        }
    }

Dapper(轻量级 ORM)

步骤:

  1. 安装 NuGet 包

    Install-Package Dapper
    Install-Package System.Data.SqlClient
  2. 执行查询

    using Dapper;
    using System.Data;
    public IEnumerable<Product> GetProducts()
    {
        using (IDbConnection db = new SqlConnection(connectionString))
        {
            return db.Query<Product>("SELECT * FROM Products");
        }
    }

关键注意事项

  1. 安全防护

    • 防 SQL 注入:使用参数化查询(ADO.NET 的 SqlParameter / Dapper 的参数化 / EF Core 的 LINQ)。
      // ADO.NET 参数化示例
      SqlCommand cmd = new SqlCommand("SELECT * FROM Users WHERE Username = @User", conn);
      cmd.Parameters.AddWithValue("@User", userInput);
  2. 连接管理

    asp.net怎样访问数据库

    • 使用 using 语句确保连接关闭(如上文示例)。
  3. 配置管理

    • 不要硬编码连接字符串,始终从配置文件读取。
  4. 异步操作(提升性能)

    // EF Core 异步示例
    var products = await _context.Products.ToListAsync();
    // Dapper 异步示例
    var products = await db.QueryAsync<Product>("SELECT * FROM Products");

各方案对比

方法 优点 适用场景
ADO.NET 高性能,完全控制 SQL 需要精细控制 SQL/存储过程
EF Core 开发快,强类型,迁移支持 快速开发,复杂对象关系
Dapper 高性能,简单易用 读写频繁的轻量级应用

根据项目需求选择合适的技术栈,新项目推荐 EF Core 或 Dapper,遗留系统可使用 ADO.NET。

图片来源于AI模型,如侵权请联系管理员。作者:酷小编,如若转载,请注明出处:https://www.kufanyun.com/ask/287874.html

(0)
上一篇 2026年2月8日 15:58
下一篇 2026年2月8日 16:01

相关推荐

  • 在ASP.NET开发中,如何编写高效查询数据库的代码?

    在ASP.NET应用开发中,数据库查询是支撑业务逻辑的核心环节,高效、稳定的查询代码不仅能提升系统性能,还能增强用户体验,掌握ASP.NET下的数据库查询技术,尤其是利用LINQ、Entity Framework等现代工具,对于构建健壮的后端系统至关重要,本文将系统阐述ASP.NET中常用的数据库查询方法、代码……

    2026年2月2日
    0210
  • hl-3150cdn打印机专用废墨粉盒究竟是什么部件?有何作用?

    hl-3150cdn的废墨粉盒是啥:什么是hl-3150cdn的废墨粉盒?hl-3150cdn的废墨粉盒,也被称为废粉盒或废粉仓,是打印机中一个重要的组成部分,它主要负责收集打印机在打印过程中产生的废粉,以保证打印质量的稳定性和打印机的正常运行,hl-3150cdn废墨粉盒的作用防止废粉污染在打印过程中,由于各……

    2025年12月6日
    01280
  • ASP.NET异步读取数据库时如何避免线程阻塞?高效数据库访问的关键技巧是什么?

    ASP.NET异步读取数据库:技术解析与最佳实践核心概念与优势在ASP.NET应用中,数据库操作是I/O密集型任务,传统同步方式会导致线程阻塞,影响并发能力,异步编程通过Task和async/await关键字,将耗时操作(如数据库读取)委托给操作系统,线程可继续处理其他任务,其核心优势包括:提升并发能力:避免线……

    2026年1月3日
    0490
    • 服务器间歇性无响应是什么原因?如何排查解决?

      根源分析、排查逻辑与解决方案服务器间歇性无响应是IT运维中常见的复杂问题,指服务器在特定场景下(如高并发时段、特定操作触发时)出现短暂无响应、延迟或服务中断,而非持续性的宕机,这类问题对业务连续性、用户体验和系统稳定性构成直接威胁,需结合多维度因素深入排查与解决,常见原因分析:从硬件到软件的多维溯源服务器间歇性……

      2026年1月10日
      020
  • asp.net的数据库连接字符串

    在ASP.NET开发体系中,数据库连接字符串不仅是应用程序与后端数据存储进行通信的桥梁,更是决定系统性能、安全性与稳定性的关键配置项,一个构建得当的连接字符串能够确保数据传输的高效与加密,而配置不当则可能导致连接泄漏、性能瓶颈甚至严重的安全漏洞,深入理解连接字符串的各个参数及其在不同环境下的最佳实践,是每一位专……

    2026年2月4日
    0140

发表回复

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