EF Core 连接 PostgreSQL 需三步:安装 Npgsql.EntityFrameworkCore.PostgreSQL、Microsoft.EntityFrameworkCore.Tools 和 Microsoft.EntityFrameworkCore.Design 三个 NuGet 包;在 appsettings.json 中配置 PostgreSQL 连接字符串;定义继承 DbContext 的类并在 Program.cs 中通过 AddDbContext 注册,最后执行迁移命令生成数据库。

EF Core 连接 PostgreSQL 不难,关键是三步到位:装对包、写对连接字符串、配好 DbContext。下面直接说清楚怎么做,不绕弯。
缺一不可,建议用 dotnet CLI 命令安装(兼容性更好):
dotnet ef migrations add 等)执行命令:
dotnet add package Npgsql.EntityFrameworkCore.PostgreSQL<br>dotnet add package Microsoft.EntityFrameworkCore.Tools<br>dotnet add package Microsoft.EntityFrameworkCore.Design
推荐放在 appsettings.json 里,结构清晰又方便换环境:
"ConnectionStrings": {<br> "PgConnection": "Host=localhost;Port=5432;Database=myappdb;Username=postgres;Password=your_password"<br>}注意点:
dotnet user-secrets 替代明文(开发阶段)Host 改成服务名或 IP,确保网络通(常见超时错误多因连不上)先写一个继承 DbContext 的类:
public class AppDbContext : DbContext<br>{<br> public AppDbContext(DbContextOptions<AppDbContext> options) : base(options) { }<br> public DbSet<Product> Products { get; set; }<br> protected override void OnModelCreating(ModelBuilder modelBuilder)<br> {<br> modelBuilder.Entity<Product>().ToTable("products"); // 映射到小写表名<br> }<br>}然后在 Program.cs(.NET 6+)中注册:
builder.Services.AddDbContext<AppDbContext>(options =><br> options.UseNpgsql(builder.Configuration.GetConnectionString("PgConnection")));这样后续控制器或服务里直接注入 AppDbContext 就能用了。
确保项目是启动项目,再执行:
dotnet ef migrations add InitialCreate<br>dotnet ef database update
成功后,PostgreSQL 里就会自动建好 products 表(含主键、时间戳等 EF 默认字段)。
基本上就这些。不复杂但容易忽略细节,比如包漏装、连接串端口写错、Docker 网络没打通——遇到连不上,优先查这三项。
以上就是EF Core如何连接PostgreSQL EF Core连接PostgreSQL教程的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号