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

相关推荐

  • 兄弟dcp9030cdn打印机说明书详细解读,操作难题解答?

    兄弟Dcp9030cdn打印机说明书兄弟Dcp9030cdn打印机是一款集打印、复印、扫描于一体的多功能设备,具有打印速度快、分辨率高、操作简便等特点,本说明书将详细介绍该产品的安装、使用和维护方法,安装与设置安装环境为确保打印机的正常使用,请将打印机放置在通风、干燥、无尘的环境中,避免阳光直射和高温,装置打印……

    2025年11月3日
    02900
  • 新手如何用ASP.NET做网站?完整实例操作步骤详解(附关键代码)

    在现代企业级Web开发领域,ASP.NET凭借其强大的性能、丰富的类库以及跨平台支持,依然是构建高安全性、高可扩展性网站的首选技术栈之一,为了深入探讨ASP.NET在实际项目中的应用,我们将以构建一个“企业级供应链管理系统(SCM)”为例,剖析从架构设计到部署上线的全过程,并结合云原生环境的实际经验,阐述如何打……

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

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

      2026年1月10日
      020
  • 如何轻松实现网站CDN加速?揭秘最简单开启步骤!

    网站开启CDN加速的最简单步骤随着互联网的快速发展,网站访问速度成为影响用户体验的重要因素,CDN(内容分发网络)技术通过在全球部署节点,将网站内容缓存到这些节点上,从而实现快速访问,以下是开启网站CDN加速的最简单步骤,帮助您提升网站性能,选择合适的CDN服务商在开启CDN加速之前,首先需要选择一家合适的CD……

    2025年12月4日
    02540
  • 在asp.net中,如何使用正则表达式删除指定的HTML标签?

    ASP.NET正则表达式删除指定HTML标签的代码详解在ASP.NET开发实践中,处理用户输入时清理恶意HTML标签(如<script>、<iframe>、<style>等)是保障Web应用安全的关键环节,正则表达式因其简洁高效,常被用于快速匹配并删除指定标签,本文将系统介绍……

    2026年1月24日
    01860

发表回复

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