ASP.NET如何配置数据库?详细步骤图文教程

在 ASP.NET 中配置数据库连接主要涉及以下步骤(以 SQL Server 为例,其他数据库类似):

asp.net怎么配置数据库

配置连接字符串

  1. appsettings.json 中添加连接字符串

    {
      "ConnectionStrings": {
        "DefaultConnection": "Server=你的服务器地址;Database=你的数据库名;User Id=用户名;Password=密码;"
        // 示例(本地 SQL Server):
        // "DefaultConnection": "Server=(localdb)\mssqllocaldb;Database=MyDB;Trusted_Connection=True;"
      }
    }
  2. 支持的数据库类型

    • SQL Server:Server=.;Database=MyDB;Integrated Security=True;
    • MySQL:Server=localhost;Database=MyDB;Uid=root;Pwd=123456;
    • SQLite:Data Source=MyDatabase.db;
    • PostgreSQL:Host=localhost;Database=MyDB;Username=postgres;Password=123456;

注入数据库上下文(以 Entity Framework Core 为例)

  1. 安装 NuGet 包

    • SQL Server: Microsoft.EntityFrameworkCore.SqlServer
    • MySQL: Pomelo.EntityFrameworkCore.MySql
    • SQLite: Microsoft.EntityFrameworkCore.Sqlite
  2. Program.cs 中注册 DbContext

    var builder = WebApplication.CreateBuilder(args);
    // 添加数据库上下文(根据数据库类型选择)
    builder.Services.AddDbContext<AppDbContext>(options =>
    {
        // SQL Server
        options.UseSqlServer(builder.Configuration.GetConnectionString("DefaultConnection"));
        // MySQL(使用 Pomelo 驱动)
        // options.UseMySql(builder.Configuration.GetConnectionString("DefaultConnection"), ServerVersion.AutoDetect(...));
        // SQLite
        // options.UseSqlite(builder.Configuration.GetConnectionString("DefaultConnection"));
    });

创建 DbContext 类

public class AppDbContext : DbContext
{
    public AppDbContext(DbContextOptions<AppDbContext> options) : base(options) { }
    // 定义数据表
    public DbSet<User> Users { get; set; }
}
// 实体类示例
public class User
{
    public int Id { get; set; }
    public string Name { get; set; }
}

数据库迁移(Code First)

  1. 安装 EF Core 工具

    asp.net怎么配置数据库

    dotnet tool install --global dotnet-ef
  2. 创建迁移

    dotnet ef migrations add InitialCreate
  3. 更新数据库

    dotnet ef database update

在控制器中使用数据库

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);
    }
}

不使用 EF Core 的原始 ADO.NET 连接

using System.Data.SqlClient;
public class UserRepository
{
    private readonly IConfiguration _config;
    public UserRepository(IConfiguration config)
    {
        _config = config;
    }
    public List<User> GetUsers()
    {
        var connectionString = _config.GetConnectionString("DefaultConnection");
        using (var connection = new SqlConnection(connectionString))
        {
            connection.Open();
            var command = new SqlCommand("SELECT * FROM Users", connection);
            var reader = command.ExecuteReader();
            var users = new List<User>();
            while (reader.Read())
            {
                users.Add(new User {
                    Id = (int)reader["Id"],
                    Name = (string)reader["Name"]
                });
            }
            return users;
        }
    }
}

安全注意事项

  1. 生产环境连接字符串

    • 使用环境变量或密钥管理服务(如 Azure Key Vault)
    • 在 Azure App Service 中通过“配置”>“连接字符串”设置
  2. 敏感信息保护

    # 使用 .NET 用户机密(开发环境)
    dotnet user-secrets set "ConnectionStrings:DefaultConnection" "你的连接字符串"

常见问题排查

  1. 连接失败

    asp.net怎么配置数据库

    • 检查服务器是否可访问
    • 验证用户名/密码是否正确
    • 检查防火墙设置
  2. 迁移错误

    • 确保 DbContext 已注入
    • 检查实体类与数据库表的映射

提示:对于不同数据库,只需替换连接字符串和对应的 EF Core 提供程序(UseSqlServer/UseMySql/UseSqlite),其他代码结构保持一致。

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

(0)
上一篇 2026年2月9日 01:02
下一篇 2026年2月9日 01:08

相关推荐

  • 公众号服务器能做论坛吗,公众号服务器搭建论坛需要什么条件

    技术可行、成本可控、体验更优的轻量级社区新范式在移动互联网流量见顶的当下,企业构建私域流量池的需求日益迫切,许多团队尝试将公众号与论坛功能融合,但受限于技术认知,往往陷入“公众号发帖、论坛跳转”的割裂体验,核心结论是:公众号服务器完全可支撑轻量级论坛功能,通过合理架构设计,既能实现内容沉淀与用户互动闭环,又能大……

    2026年4月12日
    0663
  • 光纤网络超级不稳定怎么办?光纤网络不稳定原因及解决方法

    2026 年光纤网络超级不稳定的核心症结已非单纯的光衰,而是光猫散热失效、运营商波分复用(WDM)端口拥塞及家庭内网设备兼容性问题,需通过更换支持 Wi-Fi 7 的千兆光猫、优化 ODN 链路及排查终端干扰来根治,光纤网络不稳定的深层逻辑与 2026 新变量随着 2026 年全光网(F5G-A)的普及,光纤接……

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

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

      2026年1月10日
      020
  • 在使用HBase执行关闭命令关闭不了的解决方法

    执行stop-hbase.sh时,等待很长时间都没结束(出来很多“…”)或没反应,介绍一下两种解决方法: 方法1 hbase-daemons.sh stop maste…

    2021年11月24日
    01.6K0
  • 公众号智慧停车场功能怎么用?智慧停车场系统功能有哪些

    公众号智慧停车场功能在数字化转型的浪潮下,智慧停车系统的核心价值已不再局限于简单的车辆计数与收费,而是演变为城市级交通治理的“神经末梢”与商业运营的“流量引擎”,真正的智慧停车,必须构建起从“入口感知”到“数据决策”的闭环生态,通过实时数据驱动、无人化运营与场景化服务,实现通行效率提升 30% 以上、运营成本降……

    2026年4月27日
    0391

发表回复

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