ASP.NET如何连接SQL数据库?详解连接步骤与配置方法

在ASP.NET中连接SQL数据库,主要有两种常用方式:ADO.NET(直接使用数据库连接)和Entity Framework(ORM框架),以下是详细步骤和示例:

asp.net怎么连接sql数据库


方式1:使用ADO.NET(基础方法)

步骤:

  1. 添加连接字符串到Web.config

    <configuration>
      <connectionStrings>
        <add name="MyDbConnection" 
             connectionString="Server=服务器地址;Database=数据库名;User Id=用户名;Password=密码;"
             providerName="System.Data.SqlClient"/>
      </connectionStrings>
    </configuration>
  2. C#代码中连接数据库

    using System.Data.SqlClient;
    using System.Configuration;
    public void GetData()
    {
        // 从Web.config获取连接字符串
        string connString = ConfigurationManager.ConnectionStrings["MyDbConnection"].ConnectionString;
        using (SqlConnection conn = new SqlConnection(connString))
        {
            conn.Open();
            string sql = "SELECT * FROM Users";
            SqlCommand cmd = new SqlCommand(sql, conn);
            // 读取数据
            SqlDataReader reader = cmd.ExecuteReader();
            while (reader.Read())
            {
                string name = reader["Name"].ToString();
                // 处理数据...
            }
        }
    }

方式2:使用Entity Framework Core(推荐)

步骤:

  1. 安装NuGet包

    • Microsoft.EntityFrameworkCore.SqlServer
    • Microsoft.EntityFrameworkCore.Design(用于迁移)
  2. 创建数据模型

    public class User
    {
        public int Id { get; set; }
        public string Name { get; set; }
    }
  3. 创建DbContext类

    asp.net怎么连接sql数据库

    using Microsoft.EntityFrameworkCore;
    public class AppDbContext : DbContext
    {
        public DbSet<User> Users { get; set; }
        protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
        {
            optionsBuilder.UseSqlServer("Server=服务器;Database=数据库;User Id=用户;Password=密码;");
        }
    }
  4. 在控制器中使用数据库

    public class UserController : Controller
    {
        private readonly AppDbContext _context;
        public UserController(AppDbContext context)
        {
            _context = context;
        }
        public IActionResult Index()
        {
            var users = _context.Users.ToList(); // 获取所有用户
            return View(users);
        }
    }
  5. 配置依赖注入(在Program.cs中)

    var builder = WebApplication.CreateBuilder(args);
    builder.Services.AddDbContext<AppDbContext>(options =>
        options.UseSqlServer(builder.Configuration.GetConnectionString("DefaultConnection")));

关键注意事项:

  1. 安全性

    • 不要在代码中硬编码连接字符串,始终使用Web.configappsettings.json
    • 使用集成身份验证(Windows验证)更安全:
      connectionString="Server=.;Database=MyDB;Integrated Security=True;"
  2. 异常处理

    try
    {
        // 数据库操作
    }
    catch (SqlException ex)
    {
        // 处理数据库异常
    }
  3. 连接池优化

    asp.net怎么连接sql数据库

    • ADO.NET默认启用连接池,使用using确保连接及时释放。

简化开发技巧:

  • 脚手架生成
    使用Visual Studio的ADO.NET实体数据模型向导自动生成DbContext和模型类。
  • 异步操作
    使用ExecuteReaderAsync()或EF Core的ToListAsync()提升性能。

    var users = await _context.Users.ToListAsync();

示例:完整ASP.NET Core流程

  1. appsettings.json配置

    {
      "ConnectionStrings": {
        "DefaultConnection": "Server=.;Database=MyAppDb;Integrated Security=True;"
      }
    }
  2. Program.cs注入服务

    builder.Services.AddDbContext<AppDbContext>(options =>
        options.UseSqlServer(builder.Configuration.GetConnectionString("DefaultConnection")));
  3. 通过依赖注入使用DbContext

    public class UserService
    {
        private readonly AppDbContext _db;
        public UserService(AppDbContext db) => _db = db;
        public void AddUser(string name)
        {
            _db.Users.Add(new User { Name = name });
            _db.SaveChanges();
        }
    }

选择方法:

  • 需要直接控制SQL → ADO.NET
  • 快速开发/维护 → Entity Framework Core
    根据项目需求灵活选用!

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

(0)
上一篇 2026年2月9日 10:01
下一篇 2026年2月9日 10:04

相关推荐

  • asp.net4安装

    在构建企业级Web应用时,ASP.NET 4(特别是ASP.NET 4.8作为.NET Framework的最新版本)依然扮演着至关重要的角色,尤其是在维护遗留系统和保障核心业务稳定性方面,安装ASP.NET 4不仅仅是运行一个安装程序,它涉及到操作系统底层组件的交互、IIS(Internet Informat……

    2026年2月4日
    0510
  • 佳能lbp623cdn激光打印机值得购买吗?性能与性价比分析揭秘!

    佳能LBP623CDN激光打印机:高效办公的得力助手佳能LBP623CDN激光打印机是一款专为高效办公设计的高性能打印机,它具有打印速度快、打印质量高、操作简便等特点,是现代办公环境中不可或缺的得力助手,产品特点高速打印佳能LBP623CDN激光打印机采用先进的激光打印技术,打印速度高达20页/分钟,满足您快速……

    2025年12月1日
    01150
  • asp.net有哪些显著优点,使其在Web开发中备受青睐?

    ASP.NET 优点详解高性能1 内存管理ASP.NET 采用 .NET 框架,该框架提供了强大的内存管理功能,通过垃圾回收机制,ASP.NET 能够自动回收不再使用的内存,从而提高应用程序的性能,2 垃圾回收优化.NET 框架中的垃圾回收器(GC)经过优化,能够高效地处理内存分配和回收,这使得 ASP.NET……

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

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

      2026年1月10日
      020
  • asp.net基础知识涵盖哪些关键内容?如何高效学习?

    ASP.NET基础知识什么是ASP.NET?ASP.NET是一种由微软开发的开源、跨平台的Web应用程序框架,用于构建动态网站、网络服务和网络应用程序,它基于.NET框架,利用C#、VB.NET等编程语言,为开发者提供了丰富的类库和工具,简化了Web应用程序的开发过程,ASP.NET的核心组件ASP.NET C……

    2025年12月14日
    01150

发表回复

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