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如何有效提升我的站点访问速度?

    随着互联网的快速发展,网站速度已成为用户评价和搜索引擎排名的重要因素,为了提升网站访问速度,优化用户体验,越来越多的网站选择使用CDN(内容分发网络)服务,七牛云作为国内领先的云服务提供商,其融合CDN服务能够有效加速你的站点,提升访问速度,以下是关于如何利用七牛云融合CDN加速你的站点的详细介绍,什么是七牛云……

    2025年12月6日
    01070
  • 如何用ASP.NET实现个人信息注册页面并跳转显示?

    ASP.NET实现个人信息注册页面并跳转显示的技术实践与优化技术准备与项目环境搭建在开发ASP.NET个人信息注册页面时,首先需完成开发环境的搭建与项目初始化,以Visual Studio 2022为例,具体步骤如下:安装开发工具:下载并安装Visual Studio 2022,选择“Web开发”工作负载,确保……

    2026年1月9日
    0600
  • HL4150CDN打印机纸盒感应器故障排查?纸盒感应不灵的解决方法是什么?

    HL4150CDN打印机纸盒感应器:关键部件解析与维护指南纸盒感应器的作用HL4150CDN打印机纸盒感应器是打印机中一个重要的部件,其主要作用是检测纸盒中的纸张数量和类型,确保打印机能够正确地送纸打印,该感应器对于保证打印质量、提高打印效率具有重要意义,纸盒感应器的工作原理纸盒感应器通常采用光电传感器或电容传……

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

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

      2026年1月10日
      020
  • 为什么选择ASP.NET开发网站?其优势主要体现在哪些方面?

    ASP.NET开发网站的优势ASP.NET是微软推出的基于.NET平台的Web开发框架,自2002年发布以来,经过多次迭代优化,已成为构建动态网站、Web应用程序和Web服务的核心工具,其强大的性能、安全性和开发效率,使其在企业级应用和大型网站开发中占据重要地位,本文将从多个维度详细解析ASP.NET开发的优势……

    2026年1月5日
    0600

发表回复

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