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

相关推荐

  • 光电图像科学与技术是什么,光电图像技术发展前景怎么样

    2026 年光电图像技术已全面跨越“可见光”局限,进入“多模态融合 + 端侧 AI 实时推理”的新阶段,核心突破在于量子点探测器与神经形态视觉芯片的产业化落地,彻底解决了低照度与高动态场景下的成像瓶颈,技术范式重构:从“光学成像”到“感知智能”的跃迁2026 年,光电图像科学与技术不再单纯追求分辨率的线性增长……

    2026年5月3日
    0403
  • 如何配置服务器CDN加速后实现SSL加密?

    服务器开启CDN加速后,为了确保网站的安全性,通常需要为CDN服务配置SSL证书,以下是一篇详细介绍如何为开启CDN加速的服务器配置SSL的文章,SSL证书配置步骤购买SSL证书您需要从SSL证书颁发机构(CA)购买SSL证书,根据您的需求,可以选择单域名证书、多域名证书或通配符证书等不同类型的SSL证书,生成……

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

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

      2026年1月10日
      020
  • ASP.NET求和实现疑问,如何高效实现数据求和逻辑?

    ASP.NET作为企业级Web应用的核心开发框架,在数据处理环节频繁涉及“求和”这一基础运算,无论是统计用户消费总额、计算商品库存总和,还是分析业务指标,高效的求和逻辑是保障系统性能与数据准确性的关键,本文将从基础实现、LINQ应用、数据库操作等多个维度深入探讨ASP.NET中的求和技术,并结合酷番云云产品经验……

    2026年1月21日
    01145
  • 如何快速辨别一个网站是否使用了CDN技术?

    在当今互联网时代,网站速度和稳定性对于用户体验至关重要,CDN(内容分发网络)作为一种提升网站性能的技术,越来越受到重视,如何判断一个网站是否使用了CDN呢?以下是一些实用的方法和步骤,CDN简介CDN是一种将网站内容存储在多个地理位置的服务器上的技术,当用户访问网站时,服务器会根据用户的地理位置,将最接近用户……

    2025年12月7日
    03090

发表回复

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