C# 使用EntityFramework CodeFirst 创建PostgreSQL数据库的详细过程

 更新时间:2023年07月28日 14:55:11   作者:othersheart  
这篇文章主要介绍了C#使用EntityFramework CodeFirst创建PostgreSQL数据库的过程,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

C# 使用EntityFramework CodeFirst 创建PostgreSQL数据库

1.先创建一个ASP.Net Web应用程序,选择Web API

2、创建EntityLib、EF、AppService三个类库。EntityLib用于存放数据库表所对应的实体,AppService用于编写用户对实体的一些操作方法,如增删改查等操作。

创建好所有类库之后,需要添加引用库EntityFramework6.Npgsql,右击项目中的引用———》管理NuGet程序包———》搜索EntityFramework6.Npgsql添加到项目中,这个库会自动添加EntityFramework6和Npgsql的引用。需要给EF、AppService和API都添加这个引用。添加完成之后就开始写各个类库相应的代码了。

EFContext类

public class EFContext : DbContext
    {
        public EFContext() : base("Postgresql")//连接字符串名称
        {
        }
        protected override void OnModelCreating(DbModelBuilder modelBuilder)
        {
            modelBuilder.HasDefaultSchema("public");//EF默认创建到dbo架构中,而PostgreSQL默认为public架构
            modelBuilder.Conventions.Remove<PluralizingTableNameConvention>();
            base.OnModelCreating(modelBuilder);
        }
        public DbSet<User> Users { get; set; }
    }

User类

[Table("User",Schema ="public")]
    public class User
    {
        [Key]
        [Required]
        [Column("ID")]
        public int ID { get; set; }
        public string Name { get; set; }
        public string Account { get; set; }
        public string Password { get; set; }
    }

AppService类

public class UserService
    {
        public void AddUser(User user)
        {
            try
            {
                using (var db = new EFContext())
                {
                    db.Users.Add(user);
                    db.SaveChanges();
                }
            }
            catch (Exception e)
            {
                string msg = e.Message;
            }
        }
        public void DeleteUserByID(int id)
        {
            try
            {
                using (var db = new EFContext())
                {
                    db.Users.Remove(db.Users.Find(id));
                    db.SaveChanges();
                }
            }
            catch (Exception e)
            {
                string msg = e.Message;
            }
        }
        public void EditUser(User user)
        {
            try
            {
                using (var db = new EFContext())
                {
                    User u = db.Users.Find(user.ID);
                    u.Name = user.Name;
                    u.Account = user.Account;
                    u.Password = user.Password;
                    db.SaveChanges();
                }
            }
            catch (Exception e)
            {
                string msg = e.Message;
            }
        }
        public User FindUserByID(int id)
        {
            try
            {
                using (var db = new EFContext())
                {
                    User user = db.Users.Find(id);
                    return user;
                }
            }
            catch (Exception e)
            {
                string msg = e.Message;
                return null;
            }
        }
        public List<User> FindAll()
        {
            try
            {
                using (var db = new EFContext())
                {
                    List<User> users = db.Users.ToList();
                    return users;
                }
            }
            catch (Exception e)
            {
                string msg = e.Message;
                return null;
            }
        }
    }

完成类的编写之后,需要添加数据库连接字符串,打开API的web.config文件添加:

<connectionStrings>
        <add name="Postgresql" connectionString="PORT=502;DATABASE=postgres;HOST=10.60.140.1;PASSWORD=007;USER ID=postgres" providerName="Npgsql" />
    </connectionStrings>

3.进行数据迁移,通过命令将实体类导入数据库生成相应的数据库表。先打开VS的工具,然后点击NuGet包管理器 ,选择程序包管理器控制台,默认项目改为EF,输入以下三行命令

1-》enable-migrations

2-》add-migration

3-》update-database

去PostgreSQL数据库去查看发现已经生成好了数据库和对应的表了,这里因为我postgres数据库已经有User表了,所以修改了一下数据库连接字符串

到此这篇关于C# 使用EntityFramework CodeFirst 创建PostgreSQL数据库的文章就介绍到这了,更多相关C# 创建PostgreSQL数据库内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 如何在C#中使用指针

    如何在C#中使用指针

    这篇文章主要介绍了如何在C#中使用指针,文中代码简单易懂,帮助大家更好的工作和学习,感兴趣的朋友快来了解下
    2020-06-06
  • C#使用哈希表实现XML文件查询

    C#使用哈希表实现XML文件查询

    这篇文章主要为大家详细介绍了C#如何使用哈希表实现XML文件查询功能,文中的示例代码讲解详细,具有一定的借鉴价值,有需要的小伙伴可以参考下
    2024-02-02
  • 分享WCF文件传输实现方法---WCFFileTransfer

    分享WCF文件传输实现方法---WCFFileTransfer

    这篇文章主要介绍了分享WCF文件传输实现方法---WCFFileTransfer,需要的朋友可以参考下
    2015-11-11
  • C# 键值对数据排序代码

    C# 键值对数据排序代码

    这篇文章介绍了C# 键值对数据排序代码,有需要的朋友可以参考一下
    2013-11-11
  • C#设计模式之适配器模式与装饰器模式的实现

    C#设计模式之适配器模式与装饰器模式的实现

    创建型设计模式主要是为了解决创建对象的问题,而结构型设计模式则是为了解决已有对象的使用问题。本文将用C#语言实现结构型设计模式中的适配器模式与装饰器模式,感兴趣的可以了解一下
    2022-04-04
  • 使用C#代码实现Excel与Open XML格式互相转换

    使用C#代码实现Excel与Open XML格式互相转换

    Open XML是一种基于XML的文件格式,由Microsoft开发,用于存储和交换多种类型的文件,在实际应用中,有时需要将Excel文件转换为 Open XML 格式,以便在其他软件中顺利打开和读取,本文将介绍如何在 C#和VB.NET中实现Excel与Open XML格式的相互转换,需要的朋友可以参考下
    2026-03-03
  • Unity的IPostprocessBuildWithReport实用案例深入解析

    Unity的IPostprocessBuildWithReport实用案例深入解析

    这篇文章主要为大家介绍了Unity的IPostprocessBuildWithReport实用案例深入解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-05-05
  • 详解C#压缩、解压文件夹/文件(带密码)

    详解C#压缩、解压文件夹/文件(带密码)

    这篇文章主要给大家介绍了关于C#压缩、解压文件夹/文件(带密码)的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-09-09
  • 浅谈C# async await 死锁问题总结

    浅谈C# async await 死锁问题总结

    这篇文章主要介绍了浅谈C# async await 死锁问题总结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-10-10
  • c# 接口使用实例

    c# 接口使用实例

    这篇文章主要介绍了c#接口使用的实例,文中讲解非常细致,代码帮助大家更好的理解和学习,感兴趣的朋友可以了解下
    2020-07-07

最新评论