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

相关推荐

  • 电视为何无法从CDN获取HLS文件?技术故障还是配置错误?

    电视无法从CDN获取HLS文件怎么回事?什么是CDN和HLS?分发网络)是一种网络技术,通过在全球范围内部署多个节点,将用户请求的内容从最近的节点返回,从而提高内容访问速度和用户体验,HLS(HTTP Live Streaming)是一种流媒体传输协议,可以将音视频内容分割成多个小片段,通过HTTP协议进行传输……

    2025年12月2日
    04210
  • 光健康的办公室智能照明控制系统,办公室智能照明系统怎么选

    光健康的办公室智能照明控制系统通过自适应调光与光谱管理,能显著提升员工视力健康与工作效率,2026年主流方案价格区间在80-150元/平米,核心在于符合GB/T 9473-2017及最新人因照明标准, 为什么2026年的办公室照明必须“智能”且“健康”?传统照明仅解决“看见”的问题,而智能健康照明解决的是“看得……

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

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

      2026年1月10日
      020
  • 光纤通信专用网络报价是多少?光纤通信网络报价及价格详情

    2026 年光纤通信专用网络报价受传输距离、带宽需求及部署环境(室内/室外/海底)影响,单芯单模光缆铺设综合成本(含材料、施工、调试)通常在15 元至 45 元/米区间,而企业级专用网络整体项目(含光端机、交换机、布线)每节点平均造价约为5 万至 8.5 万元,具体需结合光纤通信专用网络报价中的定制化参数核算……

    2026年5月3日
    03001
  • asp.net MVC下ajax参数提交不匹配,如何高效解决?

    ASP.NET MVC 中使用 AJAX 提交参数的匹配问题深度解析与最佳实践在 ASP.NET MVC 开发中,AJAX 技术是实现动态、无刷新用户体验的核心手段,当开发者尝试提交复杂数据结构(如嵌套对象、数组、集合)时,常常遭遇参数无法正确匹配到后端 Action 方法参数的困境,这种“参数丢失”或“绑定失……

    2026年2月5日
    01690

发表回复

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