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作为微软推出的一个流行的Web开发框架,曾一度受到广泛关注,随着技术的发展和需求的变迁,一些开发者开始对ASP.NET提出质疑,认为它“很烂”,本文将从几个方面探讨这一观点,并提供一些解决方案,性能问题重量级框架ASP.NET框架相对较重,这导致了它在性能上存在一定的劣势,尤其……

    2025年12月13日
    01200
  • Z41H一16CDN250长度规格是什么型号,有何特别之处?

    Z41H一16CDN250:深度解析这款高性能电机的关键特性与应用Z41H一16CDN250是一款高性能电机,由知名电机制造商研发生产,该电机以其卓越的性能、稳定的运行和广泛的适用性,在工业领域得到了广泛的应用,本文将详细解析这款电机的关键特性及其应用领域,关键特性高效率Z41H一16CDN250电机采用先进的……

    2025年12月7日
    0880
  • 佳能MF746CX与MF810CDN,两款打印机有何显著差异?

    佳能MF746CX与MF810CDN:高效办公打印解决方案佳能MF746CX和MF810CDN是佳能公司推出的两款高效办公打印解决方案,旨在满足不同规模企业的打印需求,这两款产品在性能、功能以及设计上都有其独特之处,以下将详细介绍这两款产品的特点,佳能MF746CX高效打印佳能MF746CX支持高速打印,黑白打……

    2025年11月29日
    0910
    • 服务器间歇性无响应是什么原因?如何排查解决?

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

      2026年1月10日
      020
  • ASP table数据查询异常,如何排查与修复问题?

    ASP表格是Web应用开发中不可或缺的技术组件,尤其在企业级业务系统中承担着数据交互、动态内容生成与业务流程支持的核心角色,它通过将HTML、脚本语言(如VBScript、JScript)与ASP代码相结合,实现了前端与后端的无缝衔接,是企业数字化转型中数据管理、业务展示与用户交互的关键工具,随着企业对数据驱动……

    2026年1月19日
    0660

发表回复

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