700字范文,内容丰富有趣,生活中的好帮手!
700字范文 > .NET Core中如何使用Entity Framework操作PostgreSQL?

.NET Core中如何使用Entity Framework操作PostgreSQL?

时间:2023-06-08 07:11:40

相关推荐

.NET Core中如何使用Entity Framework操作PostgreSQL?

后端开发|C#.Net教程

.NET,Entity Framework,PostgreSQL

后端开发-C#.Net教程

本篇文章给大家带来的内容是介绍.NET Core中使用Entity Framework操作PostgreSQL的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所助。

制作word源码下载,Ubuntu怎么禁用cpu,东京大学爬虫,php pathon,seo运营流程lzw

Entity Framework在.NET Core中被命名为Entity Framework Core。虽然一般会用于对SQL Server数据库进行数据操作,但其实它还支持其它数据库,这里就以PostgreSQL作为例子。

6603棋牌源码 引擎,vscode输入一直是全角,ubuntu如何编译,tomcat服务器链接,免费爬虫mysql,php语言基础教程,云阳智能化seo推广包含什么lzw

PostgreSQL

PostgreSQL可以选用原生系统与Docker两种安装方式。

截图工具源码,ubuntu中edu,tomcat8 异步化,语言开发爬虫,php精解案例教程 代码,普兰店seo优化关键词lzw

Official

Docker

Package

在应用程序工程中添加相关的引用。

dotnet add package Npgsql.EntityFrameworkCore.PostgreSQL

Entity

编写两个实体类,用于映射User表与Order表。

public class User{ [Key] public int Id { get; set; } [Required] public string Name { get; set; } public virtual ICollection Orders { get; set; } public override string ToString() { var orders = new StringBuilder(); foreach (var o in Orders) { orders.Append(o.ToString()); } return $"UserId: {Id} Name: {Name} Orders: {orders.ToString()}"; }}

public class Order{ [Key] public int Id { get; set; } [Required] public int UserId { get; set; } [Required] public string Item { get; set; } [Required] public string Description { get; set; } public virtual User User { get; set; } public override string ToString() { return $"OrderId: {Id} Item: {Item} Descriptoin: {Description}"; }}

DbContext

构建必要的DbContext类,并传入连接PostgreSQL所需的参数。

public class PurchaseDbContext : DbContext{ public DbSet Users { get; set; } public DbSet Orders { get; set; } protected override void OnConfiguring(DbContextOptionsBuilder builder) { builder.UseNpgsql("Host=localhost;Username=postgres;Password=random;Database=Purchase"); }}

Seeder

构建一个用于初始化数据库的辅助类。

public class PurchaseDbContxtSeeder{ public static void Seed(PurchaseDbContext context) { context.Database.EnsureDeleted(); context.Database.EnsureCreated(); var users = new List {new User { Name = "Tom" },new User { Name = "Mary" } }; var orders = new List {new Order { User = users[0], Item = "cloth", Description = "handsome"},new Order {User = users[1], Item = "hat", Description = "red"},new Order {User = users[1], Item = "boot", Description = "black"} }; context.Users.AddRange(users); context.Orders.AddRange(orders); context.SaveChanges(); }}

Test

测试的程序第一步是调用生成数据的辅助类,第二步是查询数据表中的数据并在控制台中显示出来。

static void Main(string[] args){ using (var context = new PurchaseDbContext()) { PurchaseDbContxtSeeder.Seed(context); var users = context.Users.Include(u => u.Orders).ToList(); users.ForEach(u => { System.Console.WriteLine(u); }); }}

以下是显示的结果:

程序正常运行的话,数据库中应该可以看到所生成的数据表:

再查看数据表的生成脚本,可以看到字段以及表之间的关系皆通过Entity Framework自动生成。

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。